Class Murmur2MessageExtractor<M>
java.lang.Object
org.apache.pekko.cluster.sharding.typed.ShardingMessageExtractor<ShardingEnvelope<M>,M>
org.apache.pekko.cluster.sharding.typed.Murmur2MessageExtractor<M>
public final class Murmur2MessageExtractor<M>
extends ShardingMessageExtractor<ShardingEnvelope<M>,M>
The murmur2 message extractor uses the same algorithm as the default kafka partitioner
allowing kafka partitions to be mapped to shards.
This can be used with the
pekko.cluster.sharding.external.ExternalShardAllocationStrategy to have messages
processed locally.
Extend Murmur2NoEnvelopeMessageExtractor to not use a message envelope extractor.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionentityId(ShardingEnvelope<M> envelope) Extract the entity id from an incomingmessage.intThe shard identifier for a given entity id.unwrapMessage(ShardingEnvelope<M> envelope) Extract the message to send to the entity from an incomingmessage.Methods inherited from class org.apache.pekko.cluster.sharding.typed.ShardingMessageExtractor
apply, noEnvelope
-
Constructor Details
-
Murmur2MessageExtractor
public Murmur2MessageExtractor(int numberOfShards)
-
-
Method Details
-
entityId
Description copied from class:ShardingMessageExtractorExtract the entity id from an incomingmessage. Ifnullis returned the message will beunhandled, i.e. posted asUnhandledmessages on the event stream- Specified by:
entityIdin classShardingMessageExtractor<ShardingEnvelope<M>,M>
-
numberOfShards
public int numberOfShards() -
shardId
Description copied from class:ShardingMessageExtractorThe shard identifier for a given entity id. Only messages that passed theShardingMessageExtractor.entityId(E)function will be used as input to this function.- Specified by:
shardIdin classShardingMessageExtractor<ShardingEnvelope<M>,M>
-
unwrapMessage
Description copied from class:ShardingMessageExtractorExtract the message to send to the entity from an incomingmessage. Note that the extracted message does not have to be the same as the incoming message to support wrapping in message envelope that is unwrapped before sending to the entity actor.- Specified by:
unwrapMessagein classShardingMessageExtractor<ShardingEnvelope<M>,M>
-