final class ReplicationSettings[Command] extends AnyRef
Not for user extension, construct using ReplicationSettings#create
- Annotations
- @ApiMayChange() @DoNotInherit()
- Source
- ReplicationSettings.scala
- Alphabetic
- By Inheritance
- ReplicationSettings
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Value Members
- def configureEntity(configure: Function[Entity[Command, ShardingEnvelope[Command]], Entity[Command, ShardingEnvelope[Command]]]): ReplicationSettings[Command]
Allows for changing the settings of the replicated entity, such as stop message, passivation strategy etc.
- val configureEntity: Function[Entity[Command, ShardingEnvelope[Command]], Entity[Command, ShardingEnvelope[Command]]]
- val edgeReplication: Boolean
- val edgeReplicationDeliveryMaxBackoff: Duration
- val edgeReplicationDeliveryMinBackoff: Duration
- val edgeReplicationDeliveryRetries: Int
- val entityEventReplicationTimeout: Duration
- val entityTypeKey: EntityTypeKey[Command]
- val eventProducerInterceptor: Optional[EventProducerInterceptor]
- val eventProducerSettings: EventProducerSettings
- val initialConsumerFilter: List[FilterCriteria]
- val otherReplicas: Set[Replica]
- val parallelUpdates: Int
- val producerFilter: Predicate[EventEnvelope[Any]]
- val replicationProjectionProvider: ReplicationProjectionProvider
- val selfReplicaId: ReplicaId
- val streamId: String
- def toString(): String
- Definition Classes
- ReplicationSettings → AnyRef → Any
- def withEdgeReplication(edgeReplication: Boolean): ReplicationSettings[Command]
- def withEdgeReplicationDeliveryMaxBackoff(maxBackoff: Duration): ReplicationSettings[Command]
- def withEdgeReplicationDeliveryMinBackoff(minBackoff: Duration): ReplicationSettings[Command]
- def withEdgeReplicationDeliveryRetries(retries: Int): ReplicationSettings[Command]
Replicated event sourcing from edge sends each event over sharding, in case that delivery fails or times out, retry this number of times
- def withEntityEventReplicationTimeout(duration: Duration): ReplicationSettings[Command]
Set the timeout for events being completely processed after arriving to a node in the replication stream
- def withEventProducerInterceptor(interceptor: EventProducerInterceptor): ReplicationSettings[Command]
Add an interceptor to the gRPC event producer for example for authentication of incoming requests
- def withEventProducerSettings(eventProducerSettings: EventProducerSettings): ReplicationSettings[Command]
- def withInitialConsumerFilter(initialConsumerFilter: List[FilterCriteria]): ReplicationSettings[Command]
Set the initial consumer filter to use for events.
Set the initial consumer filter to use for events. Should only be used for static, up front consumer filters. Combining this with updating consumer filters directly means that the filters may be reset to these filters.
- def withOtherReplicas(otherReplicas: Set[Replica]): ReplicationSettings[Command]
- def withParallelUpdates(parallelUpdates: Int): ReplicationSettings[Command]
Run up to this many parallel updates over sharding.
Run up to this many parallel updates over sharding. Note however that updates for the same persistence id is always sequential.
- def withProducerFilter[Event](producerFilter: Predicate[EventEnvelope[Event]]): ReplicationSettings[Command]
Filter events matching the
producerFilter
predicate, for example based on tags. - def withProducerFilterTopicExpression(topicExpression: String): ReplicationSettings[Command]
Filter events matching the topic expression according to MQTT specification, including wildcards.
Filter events matching the topic expression according to MQTT specification, including wildcards. The topic of an event is defined by a tag with certain prefix, see
topic-tag-prefix
configuration. - def withProjectionProvider(projectionProvider: ReplicationProjectionProvider): ReplicationSettings[Command]
Change projection provider
- def withSelfReplicaId(selfReplicaId: ReplicaId): ReplicationSettings[Command]
- def withStreamId(streamId: String): ReplicationSettings[Command]