Actor模型开发库,Akka 2.0 发布

openkk 13年前
     <div id="p_fullcontent" class="detail">     <p><a href="/misc/goto?guid=4958191133811540042" target="_blank">Akka </a>是一个用 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 style="line-height:125%;margin:0pt;"><span style="color:#008000;">// server code</span> <span style="color:#0000ff;">class</span> <span style="color:#2b91af;">HelloWorldActor</span> <span style="color:#0000ff;">extends</span> UntypedActor {    <span style="color:#0000ff;">public</span> <span style="color:#2b91af;">void</span> onReceive(Object msg) {      getContext().reply(msg + <span style="color:#a31515;">" World"</span>);    }  }  remote().start(<span style="color:#a31515;">"localhost"</span>, 9999).register(    <span style="color:#a31515;">"hello-service"</span>,      actorOf(HelloWorldActor.class));<span style="color:#008000;">// client code</span> ActorRef actor = remote().actorFor(    <span style="color:#a31515;">"hello-service"</span>, <span style="color:#a31515;">"localhost"</span>, 9999);  Object res = actor.sendRequestReply(<span style="color:#a31515;">"Hello"</span>);</pre>     <p>Scala 代码:</p>     <pre style="line-height:125%;margin:0pt;"><span style="color:#008000;">// server code</span> <span style="color:#0000ff;">class</span> <span style="color:#2b91af;">HelloWorldActor</span> <span style="color:#0000ff;">extends</span> <span style="color:#2b91af;">Actor</span> {    <span style="color:#0000ff;">def</span> receive <span style="color:#0000ff;">=</span> {       <span style="color:#0000ff;">case</span> msg <span style="color:#0000ff;">=></span> self reply (msg + <span style="color:#a31515;">" World"</span>)    }  }  remote.start(<span style="color:#a31515;">"localhost"</span>, 9999).register(    <span style="color:#a31515;">"hello-service"</span>, actorOf[<span style="color:#2b91af;">HelloWorldActor</span>])<span style="color:#008000;">// client code</span> <span style="color:#0000ff;">val</span> actor <span style="color:#0000ff;">=</span> remote.actorFor(    <span style="color:#a31515;">"hello-service"</span>, <span style="color:#a31515;">"localhost"</span>, 9999)<span style="color:#0000ff;">val</span> result <span style="color:#0000ff;">=</span> actor !! <span style="color:#a31515;">"Hello"</span></pre>    </div>    <p><br /> Akka 2.0 刚刚发布了,下载 Akka 2.0:<a href="/misc/goto?guid=4958331858481647166">here</a>.</p>    <p>Akka 2.0 包含众多的改进,详细内容请看<a href="/misc/goto?guid=4958331859275707340" target="_blank">发行说明</a>。</p>