Packages

final case class DropOldAndSignal[A](bufferSize: Int, onOverflow: (Long) => Coeval[Option[A]]) extends Evicted[A] with Product with Serializable

A OverflowStrategy specifying that on reaching the maximum size, the currently buffered events should start being dropped in a FIFO order, so the oldest events from the buffer will be dropped first.

The given onOverflow function get be used for logging the event and for sending a message to the downstream consumers to inform them of dropped messages. The function can return None in which case no message is sent and thus you can use it just to log a warning.

bufferSize

specifies how many events our buffer can hold before overflowing

onOverflow

is a function that can get called on overflow with a number of messages that were dropped, a function that builds a new message that will be sent to downstream. If it returns None, then no message gets sent to downstream.

Source
OverflowStrategy.scala
Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. DropOldAndSignal
  2. Product
  3. Equals
  4. Evicted
  5. Synchronous
  6. OverflowStrategy
  7. Serializable
  8. AnyRef
  9. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new DropOldAndSignal(bufferSize: Int, onOverflow: (Long) => Coeval[Option[A]])

    bufferSize

    specifies how many events our buffer can hold before overflowing

    onOverflow

    is a function that can get called on overflow with a number of messages that were dropped, a function that builds a new message that will be sent to downstream. If it returns None, then no message gets sent to downstream.

Value Members

  1. val bufferSize: Int
    Definition Classes
    DropOldAndSignalEvicted
  2. val isEvicted: Boolean
    Definition Classes
    EvictedOverflowStrategy
  3. val isSynchronous: Boolean
    Definition Classes
    SynchronousOverflowStrategy
  4. val onOverflow: (Long) => Coeval[Option[A]]
  5. def productElementNames: Iterator[String]
    Definition Classes
    Product