Akka学习笔记01--简介和HelloWorld程序

来源:互联网 发布:sql sp4安装无反应 编辑:程序博客网 时间:2024/05/19 13:30

Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。

Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:

  • 系统中的所有事物都可以扮演一个Actor
  • Actor之间完全独立
  • 在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序
  • Actor由标识和当前行为描述
  • Actor可能被分成原始(primitive)和非原始(non primitive)类别
  • 非原始Actor有
    • 由一个邮件地址表示的标识
    • 当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成
  • 消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)
  • 所有消息发送都是并行的

简单示例:

import akka.actor.{Props, ActorSystem, Actor}class HelloActor extends Actor{  def receive = {    case "hello" => println("world")    case _ => println("huh?")  }}object HelloActor{  def props = Props[HelloActor]}object Boot extends App{  val system = ActorSystem("HelloSystem")  val helloActor = system.actorOf(HelloActor.props, name = "helloactor")  helloActor ! "hello"  helloActor ! "hah"  //关闭ActorSystem  system.shutdown}


1 0