Actors编程模型

  Actors模型(Actor model)首先是由Carl Hewitt在1973定义, 由Erlang OTP (Open Telecom Platform) 推广,其 消息传递更加符合面向对象的原始意图。 Actors属于并发组件模型 ,通过组件方式定义并发编程范式的高级阶段,避免使用者直接接触多线程并发或线程池等基础概念。

   传统多数流行的语言并发是基于多线程之间的共享内存,使用同步方法防止写争夺,Actors使用消息模型,每个Actors在同一时间处理最多一个消息,可以发送消息给其他Actors,保证了单独写原则 。从而巧妙避免了多线程写争夺。

   Actors模型的特点是:

    • 隔离计算实体
    • "Share nothing"
    • 没有任何地方同步
    • 异步消息传递
    • 不可变的消息 消息模型类似mailbox / queue

   AKKA框架是一个实现Actors模型的Scala或Java平台,灵感来自ERlang,能更轻松地开发可扩展,实现多线程安全应用。

  Actors是一个轻量级的对象,通过发送消息实现交互。每个Actors在同一时间处理最多一个消息,可以发送消息给其他Actors。在同一时间可以于一个Java虚拟机存在数以百万计的参与者,构架是一个分层的父层(管理) - 子层,其中父层监控子层的行为。还可以很容易地扩展Actor运行在集群中各个节点之间 - 无需修改一行代码。每个演员都可以有内部状态(字段/变量) ,但通信只能通过消息传递,不会有共享数据结构(计数器,队列) 。Akka框架支持两种语言Java和Scala,

 

WhatsApp成功背后的Erlang语言

Actor模型和CSP模型的区别

高级并发:Akka Actors和JavaEE7的EJB比较

Akka教程

AKKA框架介绍

使用Akka发送1000万消息

使用Akka实现MapReduce的单词计数

Akka+ZeroMQ消息生产者和消费者

软件事务内存STM

RXJAVA的Observable和AKKA ACTOR综合使用

为什么Actor模型是高并发事务的终极解决方案?

actor并发模型&基于共享内存线程模型

Spray + Akka高性能异步IO并发

使用Scala的Akka HTTP,Akka Stream和Reactive Mongo建立REST服务

单独写原则

LMAX架构

go reactive宣言

Scala入门之函数编程

Scala入门之基本概念

vertx入门教程

使用Kafka和ZeroMQ实现分布式Quasar Actor

David Fowler :actor框架为什么没能流行起来?

 

相关参考

Actors模型更多专题

AKKA更多专题

reactive编程

Scala专题

Disruptor专题

并发编程

性能专题

EDA事件驱动专题