Class

diode.util.Retry

Backoff

Related Doc: package Retry

Permalink

case class Backoff(retriesLeft: Int, delay: FiniteDuration, exp: Double = 2.0, filter: (Throwable) ⇒ Boolean = always)(implicit runner: RunAfter, ec: ExecutionContext) extends RetryPolicy with Product with Serializable

Provides an exponential backoff algorithm for retrying.

retriesLeft

Number of retries

delay

Delay after failure before trying again. Grows on each retry to prevDelay * exp

exp

Exponential growth factor for delay. Default is 2.0 leading to delay doubling on every retry.

filter

A filter to check if the cause of failure should prevent retrying.

Linear Supertypes
Serializable, Serializable, Product, Equals, RetryPolicy, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Backoff
  2. Serializable
  3. Serializable
  4. Product
  5. Equals
  6. RetryPolicy
  7. AnyRef
  8. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Backoff(retriesLeft: Int, delay: FiniteDuration, exp: Double = 2.0, filter: (Throwable) ⇒ Boolean = always)(implicit runner: RunAfter, ec: ExecutionContext)

    Permalink

    retriesLeft

    Number of retries

    delay

    Delay after failure before trying again. Grows on each retry to prevDelay * exp

    exp

    Exponential growth factor for delay. Default is 2.0 leading to delay doubling on every retry.

    filter

    A filter to check if the cause of failure should prevent retrying.

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  5. def canRetry(reason: Throwable): Boolean

    Permalink

    Checks if retry should be attempted.

    Checks if retry should be attempted.

    reason

    Reason for failure leading to this retry. Used for filtering.

    Definition Classes
    BackoffRetryPolicy
  6. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  7. val delay: FiniteDuration

    Permalink

    Delay after failure before trying again.

    Delay after failure before trying again. Grows on each retry to prevDelay * exp

  8. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  9. val exp: Double

    Permalink

    Exponential growth factor for delay.

    Exponential growth factor for delay. Default is 2.0 leading to delay doubling on every retry.

  10. val filter: (Throwable) ⇒ Boolean

    Permalink

    A filter to check if the cause of failure should prevent retrying.

  11. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  12. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  13. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  15. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  16. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  17. val retriesLeft: Int

    Permalink

    Number of retries

  18. def retry[T <: AnyRef](reason: Throwable, effectProvider: (RetryPolicy) ⇒ Effect): Either[Throwable, (RetryPolicy, Effect)]

    Permalink

    Retries an effect.

    Retries an effect. Returns Left if retry is not possible and Right[(RetryPolicy, Effects)] if it is.

    reason

    Reason for failure leading to this retry. Used for filtering.

    effectProvider

    Effect to be retried.

    Definition Classes
    BackoffRetryPolicy
  19. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  20. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  22. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from Serializable

Inherited from Serializable

Inherited from Product

Inherited from Equals

Inherited from RetryPolicy

Inherited from AnyRef

Inherited from Any

Ungrouped