摘要:接下来会选择一个最老的实例并在上面创建单例。可以确保整个集群中至多有一个的实例,言下之意,存在没有实例的时刻。访问需要借助于,会把所有的消息给当前被代理的实例。
上篇文章主要讲了如何使用Akka作异步任务处理。最后还抛出一个问题。
具体问题的描述就不在这篇文章赘述了,我们仅简单回顾一下第一种解决方案:覆写persistenceId()时,加一个UUID,这样三台服务器上的Actor就不会再共享journal。虽然这个方案已经可以解决问题了,但并不是最理想的。首先,现在的项目中只是用akka处理一些无状态的任务异步处理,但是将来肯定要用akka作更多的事情。比如,缓存,DAO这些可以设计成有状态的,而现在actor重启时是不能replay消息消息历史的,所以这样不能最大限度发挥actor的优势。还有,我的目标是把所有的后端server构建为一个逻辑上的server,现在他们仍然是三个各自为营的独立server。因此我又继续作了一些调研,最终发现了Cluster Singleton。
文档上给出了Cluster Singleton的适用场景:
集群中的单点决策,或者协调
统一外部系统出口
一主多从
统一命名服务或路由逻辑
第二点正好就是我们的场景。下边看一下如何使用Cluster Singleton。
添加依赖(我用的构建工具是Gradle)
compile("com.typesafe.akka:akka-cluster_2.11:${akkaVersion}") compile("com.typesafe.akka:akka-cluster-tools_2.11:${akkaVersion}")
创建actor
actorSystem.actorOf(ClusterSingletonManager.props( SpringExtProvider.get(actorSystem).props("NotificationActor"), PoisonPill.getInstance(), ClusterSingletonManagerSettings.create(actorSystem).withRole("master") ), "notification-master"); notificationActor = actorSystem.actorOf( ClusterSingletonProxy.props( "/user/notification-master", ClusterSingletonProxySettings.create(actorSystem).withRole("master")), "notification-proxy");
创建actor比原来复杂了。首先要创建一个ClusterSingletomManager。ClusterSingletonManager也是一个Actor,它会在Cluster的每个节点上都启动起来(或者集群拥有某些角色的节点)。ClusterSingletomManager.props要传入三个参数,第一个是需要创建Singleton实例的Actor配置;第二个是当Manager关闭时要给它管理的Actor发送什么消息;第三个,集群部署配置,即指定ClusterSingletomManager在哪些集群Node上启动。
接下来ClusterSingletonManager会选择一个最老的实例并在上面创建Actor单例。ClusterSingletonManager可以确保整个集群中至多有一个singleton的实例,言下之意,存在没有singleton实例的时刻。比如cluster node crash,原有的singleton实例丢失,这时需要重新选举新最老的ClusterSingletonManager,然后创建新的singleton实例。
访问Singleton Actor需要借助于ClusterSingletonProxy,ClusterSingletonProxy会把所有的消息forward给当前被代理的Actor实例。因为有可能某些时刻是没有singleton actor实例的,所以遇到这种情况ClusterSingletonProxy会先把消息缓存,当新的Actor单例创建之后,再把缓存的消息转发过去。
当然,Cluster Singleton也有它的问题,比如单点潜在的性能问题,而且singleton actor并不是100%可用。但相比于第一种方案,显然这个要更接近我的期望。
write on 2017-1-10
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/11753.html
摘要:接下来会选择一个最老的实例并在上面创建单例。可以确保整个集群中至多有一个的实例,言下之意,存在没有实例的时刻。访问需要借助于,会把所有的消息给当前被代理的实例。 上篇文章主要讲了如何使用Akka作异步任务处理。最后还抛出一个问题。 具体问题的描述就不在这篇文章赘述了,我们仅简单回顾一下第一种解决方案:覆写persistenceId()时,加一个UUID,这样三台服务器上的Actor就不...
摘要:创建订单时同步操作有查询库存,扣款,刷新库存可异步的操作有通知风控系统,给买家发送扣款邮件和短信,通知卖家,创建一些定时任务。 同步转异步是一种常见的优化手段,最近一次在做调优时便大量使用了这种方式。通常在一个业务场景中会包含多个操作,有些操作的结果需要让用户立马知道,但有些操作则不需要。这些用户不需要等待结果的操作,我们在编程的时候便可以异步处理。这么做最直接的效果就是缩短接口响应速...
摘要:以上是服务启动过程中的主体设计,其中包括了各种组件的实例化,如对象池等。 EasySwoole 服务启动过程以及主体设计流程源码解析 本文主要讲解EasySwoole 服务的启动过程,会通过源码片段讲解主体的设计流程 命令启动 当我们通过php easyswoole start启动EasySwoole 服务时,命令真正到达的文件是 easyswoole项目vendoreasyswool...
阅读 2796·2021-11-24 09:39
阅读 2557·2021-11-23 09:51
阅读 1869·2021-11-17 09:33
阅读 1752·2021-10-22 09:54
阅读 1882·2021-08-16 11:00
阅读 3435·2019-08-30 15:53
阅读 1742·2019-08-30 13:19
阅读 2914·2019-08-30 12:49