Class/Object

com.weightwatchers.reactive.kinesis.producer

KinesisProducerActor

Related Docs: object KinesisProducerActor | package producer

Permalink

class KinesisProducerActor extends Actor with LazyLogging with UnboundedStash

This Actor wraps the KinesisProducer to provide reliable handling and throttling of requests.

Upon completion of a com.weightwatchers.reactive.kinesis.producer.KinesisProducerActor.SendWithCallback, a com.weightwatchers.reactive.kinesis.producer.KinesisProducerActor.SendSuccessful or com.weightwatchers.reactive.kinesis.producer.KinesisProducerActor.SendFailed will be returned to the original sender, this allows asynchronous tracking of requests.

Internally, for each request a new Future is created to track the completion. These concurrently created Futures can be throttled by specifying the maxOutstandingRequests.

This causes subsequent requests to be queued up until the outstanding messages have been processed.

Linear Supertypes
UnboundedStash, RequiresMessageQueue[UnboundedDequeBasedMessageQueueSemantics], UnrestrictedStash, StashSupport, LazyLogging, Actor, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. KinesisProducerActor
  2. UnboundedStash
  3. RequiresMessageQueue
  4. UnrestrictedStash
  5. StashSupport
  6. LazyLogging
  7. Actor
  8. AnyRef
  9. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new KinesisProducerActor(producer: KinesisProducer, throttlingConfig: Option[ThrottlingConf])

    Permalink

    producer

    an instance of the KinesisProducer

    throttlingConfig

    Configuration which defines whether and how often to throttle.

Type Members

  1. type Receive = PartialFunction[Any, Unit]

    Permalink
    Definition Classes
    Actor

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 aroundPostRestart(reason: Throwable): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
    Annotations
    @InternalApi()
  5. def aroundPostStop(): Unit

    Permalink
    Definition Classes
    KinesisProducerActor → Actor
  6. def aroundPreRestart(reason: Throwable, message: Option[Any]): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
    Annotations
    @InternalApi()
  7. def aroundPreStart(): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
    Annotations
    @InternalApi()
  8. def aroundReceive(receive: akka.actor.Actor.Receive, msg: Any): Unit

    Permalink
    Attributes
    protected[akka]
    Definition Classes
    Actor
    Annotations
    @InternalApi()
  9. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  10. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  11. implicit val context: ActorContext

    Permalink
    Definition Classes
    Actor
  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. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  18. lazy val logger: Logger

    Permalink
    Attributes
    protected
    Definition Classes
    LazyLogging
  19. final def ne(arg0: AnyRef): Boolean

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

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

    Permalink
    Definition Classes
    AnyRef
  22. def postRestart(reason: Throwable): Unit

    Permalink
    Definition Classes
    Actor
    Annotations
    @throws( classOf[java.lang.Exception] )
  23. def postStop(): Unit

    Permalink
    Definition Classes
    UnrestrictedStash → Actor
  24. def preRestart(reason: Throwable, message: Option[Any]): Unit

    Permalink
    Definition Classes
    UnrestrictedStash → Actor
  25. def preStart(): Unit

    Permalink
    Definition Classes
    Actor
    Annotations
    @throws( classOf[java.lang.Exception] )
  26. def receive: Receive

    Permalink
    Definition Classes
    KinesisProducerActor → Actor
  27. implicit final val self: ActorRef

    Permalink
    Definition Classes
    Actor
  28. final def sender(): ActorRef

    Permalink
    Definition Classes
    Actor
  29. def stash(): Unit

    Permalink
    Definition Classes
    StashSupport
  30. def supervisorStrategy: SupervisorStrategy

    Permalink
    Definition Classes
    Actor
  31. final def synchronized[T0](arg0: ⇒ T0): T0

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

    Permalink
    Definition Classes
    AnyRef → Any
  33. def unhandled(message: Any): Unit

    Permalink
    Definition Classes
    Actor
  34. def unstashAll(): Unit

    Permalink
    Definition Classes
    StashSupport
  35. final def wait(): Unit

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

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

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

Inherited from UnboundedStash

Inherited from RequiresMessageQueue[UnboundedDequeBasedMessageQueueSemantics]

Inherited from UnrestrictedStash

Inherited from StashSupport

Inherited from LazyLogging

Inherited from Actor

Inherited from AnyRef

Inherited from Any

Ungrouped