我使用Akka.Remote从ASP.NET web应用程序调用后端的参与者(托管为Windows )。作为代码的一部分,我在远程系统上查找一个参与者,它可能存在,也可能不存在。
客户的电话如下..。
var profileActor = await someRemoteActor.Ask<IActorRef>(new LoadProfile("me@here.com"));
if (profileActor != ActorRefs.Nobody)
{
// Now do stuff with the profile
...
}在遥远的方面,代码就是这样做的.
Receive<LoadProfile>(rq =>
{
IActorRef child = ActorRefs.Nobody;
if (ProfileExistsInTheDatabase(rq.Username))
{
child = Context.ActorOf<Profile>(rq.Username);
child.Tell(rq);
}
Sender.Tell(child);
};这不是确切的代码,但是显示了这样的想法:如果在服务器端找不到什么东西,那么ActorRefs.Nobody就会返回。
现在的问题是,当ActorRefs.Nobody返回到客户机时,它被转换为远程参与者引用,这是我没想到的。我原以为ActorRefs.Nobody会遍历远程处理层,并在客户机上显示为相同的内容。
我认为这样做是错误的吗?我想是这样的,因为它不像我预期的那样工作,但是澄清一下会更好。
现在,我已经修改了代码,以返回一个消息类,其中包含一个标志,以指示远程参与者是否存在,但我更希望能够使用ActorRefs.Nobody。
提前感谢您的协助。
发布于 2016-03-24 19:44:15
在远程系统中,ActorRefs.Nobody可能不会被转换回Nobody.Instance。
作为解决办法,您可以将profileActor.Path与ActorRefs.Nobody.Path进行比较。
您可以在GitHub回购上提交有关此问题的文件,这是可以在远程层中解决的问题。
https://stackoverflow.com/questions/36021603
复制相似问题