在前面的文章《Akka学习笔记:Actor消息传递(1)》和《Akka学习笔记:Actor消息传递(2)》。我们仅仅将消息发送到Actor,并没有期待从Actor发来的响应。
从技术上讲,我们给Actor发送消息,除了没有响应,目标的Actor将对这条消息进行如下操作:
1、给发送者发送一个响应,在我们的例子中,TeacherActor将发送一个quote 到StudentActor作为响应。或者
2、给其他的Actor响应,而这个Actor可能也会作出响应或者转发等。Routers和Supervisors就是这个例子,我们将在后面看到。
请求和响应
这里我们只研究场景1
上图传达了我们此刻想表达的意思。为了简单,我没有在图中画出ActorSystem、Dispatcher 和Mailboxes。
1、DriverApp个StudentActor发送了一个InitSignal消息;
2、StudentActor对InitSignal消息作出反应,并且发送了QuoteRequest 消息给TeacherActor;
3、TeacherActor用QuoteResponse作出了响应;
4、StudentActor仅仅将QuoteResponse 作为日志打印到控制台/logger。
我们将在testcase中进行确认。让我们先来看看上面4点:
一、DriverApp个StudentActor发送了一个InitSignal消息
到现在为止,你可能已经猜到了DriverApp将要做的事,仅仅4件事
1)、初始化ActorSystem
2)、创建TeacherActor
3)、创建StudentActor
你可能注意到,我用TeacherActor 作为StudentActor构造参数,并传入到ActorRef 中,这样StudentActor 将可以用ActorRef发送消息到TeacherActor。还有其他的方法可以实现类似的功能(比如利用Props),但是当我们想查看 Supervisors 和Routers的时候,这个方法很方便。我们很快看到一个自Actors,但是在这里的语义不对:Student创建Teacher听起来很不好。不是吗?
4)、最后,DriverApp将给StudentActor发送InitSignal。所以StudentActor可以给TeacherActor发送QuoteRequest 消息。
这就是DriverClass所做的。完整的代码如下
本文英文地址:http://rerun.me/2014/10/06/akka-notes-actor-messaging-request-and-response-3/