Akka 2.3.8 发布,此版本现已提供下载,暂未有相关说明,改进内容请看 commit 列表。
Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。
Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:
系统中的所有事物都可以扮演一个Actor Actor之间完全独立 在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序 Actor由标识和当前行为描述 Actor可能被分成原始(primitive)和非原始(non primitive)类别 非原始Actor有 消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue) 所有消息发送都是并行的
Java代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 | class HelloWorldActor extends UntypedActor {
public void onReceive(Object msg) {
getContext().reply(msg + " World" );
}
}
remote().start( "localhost" , 9999 ).register(
"hello-service" ,
actorOf(HelloWorldActor. class ));
ActorRef actor = remote().actorFor(
"hello-service" , "localhost" , 9999 );
Object res = actor.sendRequestReply( "Hello" );
|
Scala 代码:
1 2 3 4 5 6 7 8 9 10 11 12 | class HelloWorldActor extends Actor {
def receive = {
case msg = > self reply (msg + " World" )
}
}
remote.start( "localhost" , 9999 ).register(
"hello-service" , actorOf[HelloWorldActor])
val actor = remote.actorFor(
"hello-service" , "localhost" , 9999 )
val result = actor !! "Hello"
|
|