官方文档: http://developer.lightbend.com/guides/akka-quickstart-java/?_ga=2.177525157.1012573474.1504767665-546319647.1504766934

一. AKKA Hello World example :

1.首先需要创建一个ActorSystem, 它是所有Actor运行的容器.

2.其次创建Greeter Actor和Printer Actor.

3.发送消息到Greeter Actor实例, 它们会先在内部存储消息.

4.最后Greeter Actor里面的指令消息会触发它们发送消息给Printer Actor, 然后Printer Actor会执行对应的操作.

二. 定义Actors和messages

messages可以是任意类型(any subtype of Object).

当定义Actors和它们的messages时, 要遵守以下规范:

1.因为messages是Actor的公共API, 所以给messages定义名称的时候要富含语义以及特定领域的意义.

2.messages是不可变的, 因为它们在不同的线程之间共享.

3.把Actor相关的messages作为静态内部类放到Actor类中, 这样更容易理解actor需要处理什么类型的消息.

4.在Actor类中, 使用静态方法props描述如何构造Actor.

 package com.lightbend.akka.sample;

 import akka.actor.AbstractActor;
import akka.actor.ActorRef;
import akka.actor.Props;
import com.lightbend.akka.sample.Printer.Greeting; public class Greeter extends AbstractActor {
static public Props props(String message, ActorRef printerActor) {
return Props.create(Greeter.class, () -> new Greeter(message, printerActor));
} static public class WhoToGreet {
public final String who; public WhoToGreet(String who) {
this.who = who;
}
} static public class Greet {
public Greet() {
}
} private final String message;
private final ActorRef printerActor;
private String greeting = ""; public Greeter(String message, ActorRef printerActor) {
this.message = message;
this.printerActor = printerActor;
} @Override
public Receive createReceive() {
return receiveBuilder()
.match(WhoToGreet.class, wtg -> {
this.greeting = message + ", " + wtg.who;
})
.match(Greet.class, x -> {
printerActor.tell(new Greeting(greeting), getSelf());
})
.build();
}
}
 package com.lightbend.akka.sample;

 import akka.actor.AbstractActor;
import akka.actor.ActorRef;
import akka.actor.Props;
import akka.event.Logging;
import akka.event.LoggingAdapter; public class Printer extends AbstractActor {
static public Props props() {
return Props.create(Printer.class, () -> new Printer());
} static public class Greeting {
public final String message; public Greeting(String message) {
this.message = message;
}
} private LoggingAdapter log = Logging.getLogger(getContext().getSystem(), this); public Printer() {
} @Override
public Receive createReceive() {
return receiveBuilder()
.match(Greeting.class, greeting -> {
log.info(greeting.message);
})
.build();
}
}

三.创建Actor对象

Actor不能用过new来创建, 而是通过工厂来创建Actor对象, 工厂返回的不是actor实例, 而是一个引用akka.actor.ActorRef, 这个引用指向actor实例.

akka.actor.ActorSystem类似于Spring的BeanFactory. 它作为Actor的容器, 管理actor的生命周期. 工厂方法actorOf通过两个参数创建Actor对象, 一个参数是配置对象Props, 一个参数是actor的名称.

 final ActorRef printerActor =
system.actorOf(Printer.props(), "printerActor");
final ActorRef howdyGreeter =
system.actorOf(Greeter.props("Howdy", printerActor), "howdyGreeter");
final ActorRef helloGreeter =
system.actorOf(Greeter.props("Hello", printerActor), "helloGreeter");
final ActorRef goodDayGreeter =
system.actorOf(Greeter.props("Good day", printerActor), "goodDayGreeter");

四. 异步通信

Actor是响应式的和消息驱动的. 一个Actor不会做任何事情知道它接收到一个消息.Actors通过异步消息来通信. 这确保了消息的发送者(sender)不用停下来等待它们的消息被接受者(recipient)处理. 相反的, 发送者只要把消息放到接收者的邮筒(mailbox)里后就可以去干别的事了. 而这个邮筒本子上是一个有序的消息队列. 来自同一个Actor的多条消息是有序的, 而来自不同的Actor的消息是交错的.

当actor不处理消息的时候是处于一个暂停的状态, 此时它不消耗除内存以外的任何资源.

五. 发送消息到Actor

把消息放到Actor的邮筒(mailbox)里, 需要调用ActorRef的tell方法.  举个栗子:

把消息发送给Greeter Actor :

 howdyGreeter.tell(new WhoToGreet("Akka"), ActorRef.noSender());
howdyGreeter.tell(new Greet(), ActorRef.noSender()); howdyGreeter.tell(new WhoToGreet("Lightbend"), ActorRef.noSender());
howdyGreeter.tell(new Greet(), ActorRef.noSender()); helloGreeter.tell(new WhoToGreet("Java"), ActorRef.noSender());
helloGreeter.tell(new Greet(), ActorRef.noSender()); goodDayGreeter.tell(new WhoToGreet("Play"), ActorRef.noSender());
goodDayGreeter.tell(new Greet(), ActorRef.noSender());

Greeter Actor给Printer Actor发送消息:

printerActor.tell(new Greeting(greeting), getSelf());

最新文章

  1. 浅谈对Js闭包的理解
  2. mysql基础用法
  3. 查看应用程序使用的所有dll
  4. 面试题一 链表中倒数第k个结点
  5. Java线程池的几种实现 及 常见问题讲解
  6. Mybatis的ResultMap的使用
  7. 【JavaScript】创建命名空间,Class,LOG
  8. SD卡中的命令CMD
  9. Spark系列(九)DAGScheduler工作原理
  10. javascript操作html元素CSS属性
  11. INTELLIJ IDEA集成CHECKSTYLE(转)
  12. 关于new Date()
  13. HDU 2504 又见GCD(最大公约数与最小公倍数变形题)
  14. unity中ScriptableObject在assetbundle中的加载
  15. 【面试】我是如何在面试别人Spring事务时“套路”对方的
  16. CoCos2dx开发:中文乱码
  17. JS的函数节流(throttle)
  18. 02Spark的左连接
  19. gitlab-ci + k8s 之gitlab-ci(一)
  20. Yii 框架的Rbac [权限控制]

热门文章

  1. 如何重置mysql中的root密码
  2. JavaScript时间日期函数
  3. 运维监控-Open-Falcon介绍
  4. Linux检查和收集硬件信息的常用命令总结
  5. 入侵检测中需要监控的注册表路径研究(Windows Registry Security Check)
  6. Vue项目搭建
  7. jQuery使用(一):jQuery对象与选择器
  8. DirectX11 With Windows SDK--04 使用DirectX Tool Kit帮助开发
  9. [leetcode-128] 最长连续序列
  10. 066、Weave如何与外网通信?(2019-04-09 周二)