Akka-是否有可能在失败的消息中通知演员的主管?

骨灰

有没有办法在演员主管的SupervisorStrategy中获得消息?我的意思是导致演员失败的人。我想从中获取一些数据。

范式的

可能的方法:

  1. 定义一个能够封装错误消息的新的运行时异常异常类。
  2. 在有监督的演员中。捕获异常,并使用错误消息抛出上面定义的异常。
  3. 在主管策略中,捕获新的异常类型并访问消息。

例如:

// The new exception type
case class MessageException( 
  akkaMessage: Any, 
  originalException: Throwable 
) extends RuntimeException("Exception due to message")

// In the supervised actor
def receive = {
  case msg => try{ process(msg) } catch { 
    case t => throw MessageException(msg,t) 
  }
}

// In the supervisor
override val supervisorStrategy =
  OneForOneStrategy(maxNrOfRetries = 10, withinTimeRange = 1 minute) {
     case MessageException(msg,t) => //decide what to do
  }

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章