
Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 AcTor 模型应用。
Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:
系统中的所有事物都可以扮演一个Actor
Actor之间完全独立
在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序
Actor由标识和当前行为描述
Actor可能被分成原始(primitive)和非原始(non primitive)类别
非原始Actor有
由一个邮件地址表示的标识
当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成
消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)
所有消息发送都是并行的
Java 代码:
public class Greeting implements Serializable {
  public final String who;
  public Greeting(String who) { this.who = who; }
}
 
public class GreetingActor extends UntypedActor {
  LoggingAdapter log = Logging.getLogger(getContext().system(), this);
 
  public void onReceive(Object message) throws Exception {
    if (message instanceof Greeting)
      log.info("Hello " + ((Greeting) message).who);
  }
}
 
ActorSystem system = ActorSystem.create("MySystem");
ActorRef greeter = system.actorOf(Props.create(GreetingActor.class), "greeter");
greeter.tell(new Greeting("CharlIE Parker"), ActorRef.nosender());
Scala 代码:
case class Greeting(who: String)
 
class GreetingActor extends Actor with ActorLogging {
  def receive = {
    case Greeting(who) ⇒ log.info("Hello " + who)
  }
}
 
val system = ActorSystem("MySystem")
val greeter = system.actorOf(Props[GreetingActor], name = "greeter")
greeter ! Greeting("Charlie Parker")
发布于 2018-01-13 00:25:13 | 264 次阅读
发布于 2018-01-11 23:53:23 | 243 次阅读
发布于 2017-09-30 00:57:12 | 196 次阅读
发布于 2017-08-10 23:22:48 | 207 次阅读
发布于 2017-06-19 23:52:32 | 172 次阅读
发布于 2017-06-14 00:24:15 | 148 次阅读
发布于 2017-05-03 23:53:37 | 169 次阅读
发布于 2017-04-12 23:49:00 | 244 次阅读
发布于 2017-03-30 23:57:00 | 175 次阅读
发布于 2017-03-17 23:31:39 | 207 次阅读
发布于 2017-02-10 23:48:31 | 190 次阅读
发布于 2017-01-26 23:48:23 | 171 次阅读
发布于 2016-12-20 00:31:00 | 225 次阅读
发布于 2016-11-22 00:18:16 | 113 次阅读
发布于 2016-11-18 23:49:14 | 120 次阅读
发布于 2016-10-28 23:59:36 | 125 次阅读
发布于 2016-10-01 00:03:04 | 139 次阅读
发布于 2016-09-13 23:19:57 | 104 次阅读
发布于 2016-09-10 23:27:31 | 126 次阅读
发布于 2016-09-09 04:22:07 | 112 次阅读