Actor模型开发库 Akka 1.2 发布
fmms 13年前
<p>Akka 1.2 发布了,高版本包含很多改进,主要是为了将要发布的 2.0 开辟道路,详细改进条目请看<a href="/misc/goto?guid=4958191133067017595" target="_blank">这里</a>。</p> <p>Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。</p> <p>Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:</p> <blockquote> <ul> <li>系统中的所有事物都可以扮演一个Actor </li> <li>Actor之间完全独立 </li> <li>在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序 </li> <li>Actor由标识和当前行为描述 </li> <li>Actor可能被分成原始(primitive)和非原始(non primitive)类别 </li> <li>非原始Actor有 <ul> <li>由一个邮件地址表示的标识 </li> <li>当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成 </li> </ul> </li> <li>消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue) </li> <li>所有消息发送都是并行的 </li> </ul> </blockquote> <p>Java代码:</p> <pre class="brush:java; toolbar: true; auto-links: false;">// server code class HelloWorldActor extends UntypedActor { public void onReceive(Object msg) { getContext().reply(msg + " World"); } } remote().start("localhost", 9999).register( "hello-service", actorOf(HelloWorldActor.class)); // client code ActorRef actor = remote().actorFor( "hello-service", "localhost", 9999); Object res = actor.sendRequestReply("Hello");</pre>Scala 代码: <pre class="brush:scala; toolbar: true; auto-links: false;">// server code class HelloWorldActor extends Actor { def receive = { case msg => self reply (msg + " World") } } remote.start("localhost", 9999).register( "hello-service", actorOf[HelloWorldActor]) // client code val actor = remote.actorFor( "hello-service", "localhost", 9999) val result = actor !! "Hello"</pre>项目地址: <a href="/misc/goto?guid=4958191133811540042" target="_blank">http://akka.io/</a> <p></p>