Class

org.squbs.pattern.stream

PersistentBuffer

Related Doc: package stream

Permalink

class PersistentBuffer[T] extends GraphStage[FlowShape[T, Event[T]]]

Persists all incoming upstream element to a memory mapped queue before publishing it to downstream consumer.

Emits when one of the inputs has an element available

Does not Backpressure upstream when downstream backpressures, instead buffers the stream element to memory mapped queue

Completes when upstream completes

Cancels when downstream cancels

In addition to this, a commit guarantee can be ensured to avoid data lost while consuming stream elements, to enable this, set the auto-commit to false and add a commit stage after downstream consumer.

Linear Supertypes
GraphStage[FlowShape[T, Event[T]]], GraphStageWithMaterializedValue[FlowShape[T, Event[T]], NotUsed], Graph[FlowShape[T, Event[T]], NotUsed], AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. PersistentBuffer
  2. GraphStage
  3. GraphStageWithMaterializedValue
  4. Graph
  5. AnyRef
  6. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new PersistentBuffer(persistDir: File)(implicit serializer: QueueSerializer[T], system: ActorSystem)

    Permalink
  2. new PersistentBuffer(config: Config)(implicit serializer: QueueSerializer[T], system: ActorSystem)

    Permalink

Type Members

  1. type Shape = FlowShape[T, Event[T]]

    Permalink
    Definition Classes
    Graph

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. def addAttributes(attr: Attributes): Graph[FlowShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    Graph
  5. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  6. def async: Graph[FlowShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    Graph
  7. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  8. def commit[S]: Flow[Event[S], Event[S], NotUsed]

    Permalink
  9. def createLogic(inheritedAttributes: Attributes): GraphStageLogic

    Permalink
    Definition Classes
    PersistentBuffer → GraphStage
  10. final def createLogicAndMaterializedValue(inheritedAttributes: Attributes): (GraphStageLogic, NotUsed)

    Permalink
    Definition Classes
    GraphStage → GraphStageWithMaterializedValue
  11. val defaultOutputPort: Int

    Permalink
  12. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  13. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  14. def finalize(): Unit

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

    Permalink
    Definition Classes
    AnyRef → Any
  16. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  17. def initialAttributes: Attributes

    Permalink
    Attributes
    protected
    Definition Classes
    GraphStageWithMaterializedValue
  18. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  19. final lazy val module: Module

    Permalink
    Definition Classes
    GraphStageWithMaterializedValue → Graph
  20. def named(name: String): Graph[FlowShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    Graph
  21. final def ne(arg0: AnyRef): Boolean

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

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

    Permalink
    Definition Classes
    AnyRef
  24. val shape: FlowShape[T, Event[T]]

    Permalink
    Definition Classes
    PersistentBuffer → Graph
  25. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  26. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  27. final def wait(): Unit

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

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

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  30. final def withAttributes(attr: Attributes): Graph[FlowShape[T, Event[T]], NotUsed]

    Permalink
    Definition Classes
    GraphStageWithMaterializedValue → Graph
  31. def withOnCommitCallback(onCommitCallback: () ⇒ Unit): PersistentBuffer[T]

    Permalink
  32. def withOnPushCallback(onPushCallback: () ⇒ Unit): PersistentBuffer[T]

    Permalink

Inherited from GraphStage[FlowShape[T, Event[T]]]

Inherited from GraphStageWithMaterializedValue[FlowShape[T, Event[T]], NotUsed]

Inherited from Graph[FlowShape[T, Event[T]], NotUsed]

Inherited from AnyRef

Inherited from Any

Ungrouped