斯卡拉 – 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

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...