微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

斯卡拉 – AKKA:无痛的演员错误通知

美丽的人生活方式

>一个组件BEAUTIFUL正在使用她的内部akka.actor.Actor来做某些事情……(比如“代理”)
>还有其他MAN组件真的想与BEAUTIFUL“互动”
>当BEAUTIFUL找到一个值得的人,在与他“互动”之前,她同意接收他的电话号码(让我们称之为ErrorHandler),你知道只是给他一个电话,以防他早上离开而忘了他的在她的床边桌上的劳力士
> BEAUTIFUL虽然是“高维护”(不是全部……),每次在BEAUTIFUL的内部演员内部发生不好的事情(例如OmgbrokenNailException,UglyPurseThrowable等等),她疯了,需要完全停止并使用该电话号码呼叫MAN(例如errorHandler.getonItNowHoney(message,throwable))

美丽的人的问题

AKKA主管允许注册两种类型的FaultHandlers => OneForOnestrategy和AllForOnestrategy,如果基础Actor重写preRestart / postRestart,它可以访问实际的“throwable”,例如:

override def preRestart( reason: Throwable ) { // do with throwable... }

问题是这两种策略都会尝试重启Actor,这不是我要找的东西.我正在寻找Actor用“throwable”调用外部ErrorHandler并停止.

如果我不使用这些策略,当从A​​ctor中抛出异常时,在Actor上调用postStop,这很酷,但它不会引入“throwable”:

override def postStop() { // no access to "throwable"... }

帮助MAN让那个扔掉

解决方法

在Akka 2中你应该使用 DeathWatch

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐