- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Akka 角色的层次结构来处理每个用户状态。有一个父actor拥有所有子actor,并以正确的方式处理get-or-create(参见a1,a2):
class UserActorRegistry extends Actor {
override def Receive = {
case msg@ DoPerUserWork(userId, _) =>
val perUserActor = getOrCreateUserActor(userId)
// perUserActor is live now, but will it receive "msg"?
perUserActor.forward(msg)
}
def getOrCreateUserActor(userId: UserId): ActorRef = {
val childName = userId.toActorName
context.child(childName) match {
case Some(child) => child
case None => context.actorOf(Props(classOf[UserActor], userId), childName)
}
}
UserActors
空闲一段时间后过期(即计时器触发子actor调用
context.stop(self)
)。
UserActorRegistry
排除它?
最佳答案
我可以看到您当前设计的两个问题使您面临您提到的竞争条件:
1)有终止条件(定时器发送毒丸)直接转到子 Actor 。通过采用这种方法,子进程当然可以在一个单独的线程(在调度程序内)上终止,同时在 UserActorRegistry
中设置了一条消息转发给它。 Actor (在调度程序内的不同线程上)。
2) 使用 PoisonPill
终止 child 。一个 PoisonPill
用于优雅停止,允许首先处理邮箱中的其他消息。在您的情况下,您由于不活动而终止,这似乎表明邮箱中没有其他消息。我看到一个 PoisonPill
这里是错误的,因为在您的情况下,可能会在 PosionPill
之后发送另一条消息在 PoisonPill
之后,该消息肯定会丢失。被处理。
因此,我建议您将非事件子代的终止委托(delegate)给 UserActorRegistry
。而不是在 children 自己身上做这件事。当您检测到不活动的情况时,向 UserActorRegistry
的实例发送消息表示需要终止特定的 child 。当您收到该消息时,通过 stop
终止该 child 。而不是发送 PoisonPill
.通过使用UserActorRegistry
的单个邮箱它以串行方式处理,您可以帮助确保在您即将向其发送消息时不会并行终止 child 。
现在,这里有一个你必须处理的复杂情况。停止 Actor 是异步的。因此,如果您调用 stop
在 child 身上,当您处理 DoPerUserWork
时,它可能不会完全停止。消息,因此可能会向它发送一条消息,该消息将丢失,因为它正在停止。您可以通过保留一些内部状态(列表)来解决此问题,该状态表示正在停止的子进程。当您停止一个 child 时,将其名称添加到该列表中,然后设置 DeathWatch
(通过 context watch child
)。当您收到 Terminated
该 child 的事件,从被终止的 child 列表中删除它的名字。如果您收到一个 child 的工作,而它的名字在该列表中,请将其重新排队以进行重新处理,可能最多重复一次,以免永远尝试重新处理。
这不是一个完美的解决方案;这只是识别您的方法中的一些问题,并插入解决其中一些问题的正确方向。如果您想查看此代码,请告诉我,我会一起制作一些东西。
编辑
回应您的第二条评论。我认为你不能看 child ActorRef
并看到它当前正在关闭,因此需要正在关闭的子列表。您可以增强 DoPerUserWork
包含 numberOfAttempts:Int 字段的消息,如果您看到目标子当前正在关闭,则递增该字段并发送回自身进行重新处理。然后,您可以使用 numberOfAttempts 来防止永远重新排队,在某个最大尝试次数处停止。如果您对依赖 DeathWatch
感到不自在,您可以向正在关闭的子项列表中的项目添加一个生存时间组件。然后,如果它们在列表中但在列表中的时间过长,则可以在遇到它们时修剪它们。
关于scala - 获取或创建子 Akka actor 并确保 liveness,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23629159/
我有以下对象: dog = { location: { x: 52.1089, y: 16.2323 }, f: function(message) { alert
在 TSQL 中,如果我要搜索有效的 .com 电子邮件地址,我需要确保有一个 @ 符号,它以 .com 结尾,并且在 @ 前后至少有一个字符。 SELECT * FROM CUSTOMER WHER
我正在尝试准备一个信用卡交易列表,以便在 Excel 2010 中进行透视和进一步分析(满足个人需求)。问题是我的银行机构没有遵循标准的日期格式,所以有时日期会显示为 Jun. 1, 2013 , 有
看来您不能在 riak 中进行交易。如何确保数据正确? 假设我们要插入评论。在 redis 我会做 commentId=incr commentCount multi SET comment_post
对于下面给定的模式,是否可以确保至少一个属性包含一个值(即 minLength 为 1): { "$schema": "http://json-schema.org/draft-04/sche
我计划在 Haxe 的一个子集中编写 Haxe 库,这些库将编译为每种 Haxe 目标语言。有什么方法可以验证 Haxe 程序是否可以编译为所有目标语言,是否可以在不手动测试每个目标平台上的编译代码的
如果浏览器窗口未聚焦,则当前页面上的所有 webdriver 标识都失败。 如何使用 webdriver 使浏览器成为焦点? 最佳答案 ((JavascriptExecutor) webDriver)
我从这样的 HTML GET 请求中获取图像链接... www.example.com?image=www.anotherdomain.com/image.jpg if (isset($_GET['i
我有一个 eunit 测试,它生成一个唯一的节点名称并开始分发: {A,B,C} = now(), Nodename = list_to_atom(lists:flatten(io_lib:forma
我正在完成我的 iPhone 应用程序。我只是担心我们的网络服务器级别的安全性。数据通过网络服务被传送到 iPhone 应用程序。 我可以在网络服务上采取哪些安全措施,以免受到攻击? 谢谢 最佳答案
我正在编写一个应用程序,该应用程序启动一个运行简单 Web 服务器的子进程。我正在使用 NSTask 并通过管道与其进行通信,一切看起来或多或少都很好。但是,如果我的程序崩溃,子进程将保持事件状态,并
我有一些应用程序,我调用 ShowMessage('Complete!');在长时间操作结束时。 大多数时候,这效果很好,但每隔一段时间,消息对话框就会显示在主窗体后面。 有什么方法可以确保 Show
我通过将消息插入集合并让模板使用 {{#each}} 打印出集合来创建一个简单的聊天。 我不太熟悉安全性,但是有没有办法让它符合 EFF 规定? https://www.eff.org/secure-
我有一个商店,我想在其中正确管理 id。假设我有以下帖子存储: type Post = { id: number; title: string; body?: string; } type
我有一个使用 ajax post 方法和数据表的程序。经过几周的摆弄,我确定我根本不明白 javascript 是如何工作的。这是我的 JavaScript: $('#SaveTimeSheet').
我有一个系统,如果从 Azure 服务总线丢失消息将是一场灾难,也就是说,数据将永远丢失,并且没有实际方法可以在不造成重大中断的情况下修复损坏。 在这种情况下我可以完全依赖 ASB 吗? (即使它
如何确保 scalatest 测试不会并行运行?在 0.12 之前,我有一个 sbt 设置: parallelExecution in Test := false 新版本引入了一些复杂的机制。这种更简
我的端点有两个如下所示的 promise : request.post({ url: url, json: smsSTART, header
简短版本 当 ui-router 转换到新 View 时(以我不完全理解的方式使用 ngAnimate),它会添加类 ng-leave 和 ng-leave-active 到当前 View 。它还将类
目前正在努力寻找验证 2 个表的方法(有效地验证表 A 的大量行) 我有两张 table 表A ID A B C 表格匹配 ID Number A 1 A 2 A 9 B 1
我是一名优秀的程序员,十分优秀!