您的位置:澳门402永利com > 关于计算机 > Actor模型开发库

Actor模型开发库

发布时间:2019-11-01 19:09编辑:关于计算机浏览(148)

    AKKA(一)认知AKKA,认知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) 所有消息发送都是并行的

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

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

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

    系统中的所有事物都可以扮演一个Actor

    Actor之间完全独立

    在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序

    Actor由标识和当前行为描述

    Actor可能被分成原始(primitive)和非原始(non primitive)类别

    非原始Actor有

    • 由一个邮件地址表示的标识
    • 当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成

    消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)

    所有消息发送都是并行的

    Java 代码:

    public class Greeting implements Serializable {
      public final String who;
      public Greeting(String who) { this.who = who; }
    }
     
    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);
      }
    }
     
    ActorSystem system = ActorSystem.create("MySystem");
    ActorRef greeter = system.actorOf(Props.create(GreetingActor.class), "greeter");
    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")

    图片 1

    图片 2

    本文由澳门402永利com发布于关于计算机,转载请注明出处:Actor模型开发库

    关键词:

上一篇:框架搭建,mybatis集成配置

下一篇:没有了