Akka Actor 模型开发
2023-11-26 本文已影响0人
梅西爱骑车
Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。Actor 目的是为了解决分布式编程中一系列的编程问题。其特点如下:
- 系统中的所有事物都可以扮演一个 Actor
- Actor 之间完全独立
- 在收到消息时 Actor 所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序
- Actor 由标识和当前行为描述
- Actor 可能被分成原始(primitive)和非原始(non primitive)类别
非原始 Actor 有:
由一个邮件地址表示的标识;当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义 1. 1. Actor 在收到消息时将采取的动作组成 - 消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)
- 所有消息发送都是并行的
Java 代码:
// 定义值对象Greeting,参数只有一个who的字符串
public class Greeting implements Serializable {
public final String who;
public Greeting(String who) { this.who = who; }
}
// 定义一个actor继承自UntypedActor ,要实现onReceive方法接收其他对象发过来的消息。
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);
}
}
// 创建系统的Actor,相当于根actor,可以实例化子actor来处理业务并发送给子actor异步接收的onReceive方法,actor是树状结构,可以有多层的子actor。
ActorSystem system = ActorSystem.create("MySystem");
ActorRef greeter = system.actorOf(Props.create(GreetingActor.class), "greeter"); // 创建了个actor实例,用ref来引用。
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")