首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Akka集群分片到分片

Akka集群分片到分片
EN

Stack Overflow用户
提问于 2018-12-15 01:09:44
回答 1查看 50关注 0票数 0

我有一个使用案例,集群中的一个分片需要向同一集群中的另一个分片询问一些信息。

我知道我可以通过这样做来获得ShardRegion:

代码语言:javascript
复制
val counterRegion: ActorRef = ClusterSharding(system).shardRegion("Counter")

然后像这样提出我的请求:

代码语言:javascript
复制
counterRegion ? InfoRequest(entityIdShardId)

但是,有没有办法从分片本身获取分片区域参与者ref呢?这似乎是一种更干净、更有效的获取ActorRef的方式。

EN

回答 1

Stack Overflow用户

发布于 2018-12-15 10:25:18

您指定的方式是正确的。

可以在分片实体中调用context.parent,返回分片地域的ActorRef。但这是一个不太明确的选项,因为它依赖于shard region是shard实体的父实体这一事实。

我认为你应该继续使用你的选择。

此外,与你的问题无关的是,你不应该在参与者中使用ask模式。它增加了处理Future的复杂性,并且需要指定超时。只需使用send/tell或!。您可以在receive分部函数中处理发回给参与者的响应。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53784127

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档