Akka
Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。它已经成功运用在电信行业。系统几乎不会宕机(高可用性 99.9999999 % 一年只有 31 ms 宕机
Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:
系统中的所有事物都可以扮演一个Actor
Actor之间完全独立
在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序
Actor由标识和当前行为描述
Actor可能被分成原始(primitive)和非原始(non primitive)类别
非原始Actor有
由一个邮件地址表示的标识
当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成
消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)
所有消息发送都是并行的
scala分布式框架-akka
(2011-09-24 18:00:21)
1、初试超轻量级actor框架——akka
http://passover.blog.51cto.com/2431658/517931
2、http://akka.io/
http://akka.io/docs/akka/1.2/java/remote-actors.html
http://typesafe.com/resources/getting-started/tutorials/getting-started-first-java.html
http://akka.io/docs/akka/1.2/java/remote-actors.html#id6
3、hello world
import akka.actor.UntypedActor;
public class HelloWorldActor extends UntypedActor {
public void onReceive(Object msg) {
getContext().reply(msg + " World");
}
}
=====================================================
import akka.actor.Actors;
import akka.remoteinterface.RemoteServerModule;
public class Server {
public static void main(String[] args) {
RemoteServerModule server = Actors.remote().start("localhost", 9999);
server.register("hello-service", Actors.actorOf(HelloWorldActor.class));
}
}
===================================================
import akka.actor.ActorRef;
import akka.actor.Actors;
public class Client {
public static void main(String[] args) {
// client code
ActorRef actor = Actors.remote().actorFor("hello-service", "localhost", 9999);
for (int i = 0; i < 10000; i++) {
Object result = actor.sendRequestReply("Hello");
System.out.println(result);
}
}
}
http://passover.blog.51cto.com/2431658/517931
2、http://akka.io/
3、hello world
import akka.actor.UntypedActor;
public class HelloWorldActor extends UntypedActor {
}
=====================================================
import akka.actor.Actors;
import akka.remoteinterface.RemoteServerModule;
public class Server {
}
===================================================
import akka.actor.ActorRef;
import akka.actor.Actors;
public class Client {
}
Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。
Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:
- 系统中的所有事物都可以扮演一个Actor
- Actor之间完全独立
- 在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序
- Actor由标识和当前行为描述
- Actor可能被分成原始(primitive)和非原始(non primitive)类别
- 非原始Actor有
- 由一个邮件地址表示的标识
- 当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成
- 消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)
- 所有消息发送都是并行的
Java代码:
// 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");
Scala 代码:
// 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"