Packages

object SupervisorStrategy extends SupervisorStrategyLowPriorityImplicits

Source
FaultHandling.scala
Content Hierarchy
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. SupervisorStrategy
  2. SupervisorStrategyLowPriorityImplicits
  3. AnyRef
  4. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Type Members

  1. type CauseDirective = (Class[_ <: Throwable], Directive)
  2. type Decider = PartialFunction[Throwable, Directive]
  3. sealed trait Directive extends AnyRef
  4. type JDecider = Function[Throwable, Directive]

Value Members

  1. final val defaultDecider: Decider

    When supervisorStrategy is not specified for an actor this Decider is used by default in the supervisor strategy.

    When supervisorStrategy is not specified for an actor this Decider is used by default in the supervisor strategy. The child will be stopped when pekko.actor.ActorInitializationException, pekko.actor.ActorKilledException, or pekko.actor.DeathPactException is thrown. It will be restarted for other Exception types. The error is escalated if it's a Throwable, i.e. Error.

  2. final val defaultStrategy: SupervisorStrategy

    When supervisorStrategy is not specified for an actor this is used by default.

    When supervisorStrategy is not specified for an actor this is used by default. OneForOneStrategy with decider defined in #defaultDecider.

  3. def escalate: Escalate

    Java API: Returning this directive escalates the failure to the supervisor of the supervisor, by rethrowing the cause of the failure, i.e.

    Java API: Returning this directive escalates the failure to the supervisor of the supervisor, by rethrowing the cause of the failure, i.e. the supervisor fails with the same exception as the child.

  4. def makeDecider(func: JDecider): Decider

    Converts a Java Decider into a Scala Decider

  5. def makeDecider(flat: Iterable[CauseDirective]): Decider

    Decider builder for Iterables of cause-directive pairs, e.g.

    Decider builder for Iterables of cause-directive pairs, e.g. a map obtained from configuration; will sort the pairs so that the most specific type is checked before all its subtypes, allowing carving out subtrees of the Throwable hierarchy.

  6. def makeDecider(trapExit: Iterable[Class[_ <: Throwable]]): Decider

    Decider builder which just checks whether one of the given Throwables matches the cause and restarts, otherwise escalates.

  7. def makeDecider(trapExit: Seq[Class[_ <: Throwable]]): Decider

    Decider builder which just checks whether one of the given Throwables matches the cause and restarts, otherwise escalates.

  8. def restart(logLevel: LogLevel): Directive

    Returning this directive discards the old Actor instance and replaces it with a new, then resumes message processing.

    Returning this directive discards the old Actor instance and replaces it with a new, then resumes message processing.

    logLevel

    Log level which will be used to log the failure

  9. def restart: Restart

    Java API: Returning this directive discards the old Actor instance and replaces it with a new, then resumes message processing.

  10. def resume(logLevel: LogLevel): Directive

    Returning this directive resumes message processing for the failed Actor.

    Returning this directive resumes message processing for the failed Actor.

    logLevel

    Log level which will be used to log the failure

  11. def resume: Resume

    Java API: Returning this directive resumes message processing for the failed Actor

  12. implicit def seqCauseDirective2Decider(trapExit: Iterable[CauseDirective]): Decider

    Implicit conversion from Seq of Cause-Directive pairs to a Decider.

    Implicit conversion from Seq of Cause-Directive pairs to a Decider. See makeDecider(causeDirective).

    Definition Classes
    SupervisorStrategyLowPriorityImplicits
  13. implicit def seqThrowable2Decider(trapExit: Seq[Class[_ <: Throwable]]): Decider

    Implicit conversion from Seq of Throwables to a Decider.

    Implicit conversion from Seq of Throwables to a Decider. This maps the given Throwables to restarts, otherwise escalates.

  14. def stop(logLevel: LogLevel): Directive

    Returning this directive stops the Actor

    Returning this directive stops the Actor

    logLevel

    Log level which will be used to log the failure

  15. def stop: Stop

    Java API: Returning this directive stops the Actor

  16. final val stoppingStrategy: SupervisorStrategy

    This strategy resembles Erlang in that failing children are always terminated (one-for-one).

  17. case object Escalate extends Directive with Product with Serializable

    Escalates the failure to the supervisor of the supervisor, by rethrowing the cause of the failure, i.e.

    Escalates the failure to the supervisor of the supervisor, by rethrowing the cause of the failure, i.e. the supervisor fails with the same exception as the child.

  18. case object Restart extends Restart with Product with Serializable

    Discards the old Actor instance and replaces it with a new, then resumes message processing.

  19. case object Resume extends Resume with Product with Serializable

    Resumes message processing for the failed Actor

  20. case object Stop extends Stop with Product with Serializable

    Stops the Actor