Skip to content

Cluster sharding: Expose entity ID to the sharded actor #24053

@talpr

Description

@talpr

Apologies in advance if this issue was brought up in the past. I tried to search for it, but couldn't find anything...

Currently, sharded actors don't have access to their entity identifier. The example in the docs uses self.path.name, but that is URL-encoded and not the actual ID. On top of that, this seems to be an implementation detail - the encoded ID happens to be what the shard uses for the actor name. At the same time, it is obvious that adding an Actor.entityId method is not a good solution (actors don't know whether or not they're sharded).

So I suggest modifying the ClusterSharding.start (or adding another API next to it) so that instead of taking Props as a parameter, it would take a String => Props function that would get invoked with the entity ID. What do you think?

(Of course, I wouldn't mind doing a PR for it, if there's interest)

Metadata

Metadata

Assignees

No one assigned

    Labels

    help wantedIssues that the core team will likely not have time to work onnice-to-have (low-prio)Tasks which make sense, however are not very high priority, feel free to help out!t:cluster-sharding

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions