AKKA actor model 的一些思考
所属分类 akka
浏览量 720
Actor 线程间通信
CSP并发模型
Communicating Sequential Processes
独立的并发实体通过共享的通讯 Channel(管道)进行通信
Go CSP 模式 与 常见的Actor模式区别(akka Erlang 使用 Actor模式)
Actor直接通讯,CSP 通过Channel进行通讯,更松的耦合
Go channel 有容量限制 并且独立于处理GOroutine
Erlang Actor模式中的mailbox容量无限,接收进程总是被动地处理消息
得益于golang runtime优秀的调度系统,阻塞goroutine不会真正的block底层的线程
Scala 初期本身包含Actor Model,后来的版本从语言核心实现中移除,
以库的方式 ,也就是 AKKA ,包含了大量的工具,比如http的实现,stream的构建以及分布式和持久化等特性
线程是一种昂贵的资源
高效的利用线程
netty 利用很少的 worker 线程 和 boss 线程 来处理 大量的连接
Actor 特点
底层默认使用 ForkJoin线程池
java.util.concurrent.ForkJoinPool
ForkJoin线程池 能够最大化的保证每个CPU的任务队列均衡,如果出现空闲会从其他的队列偷取任务来计算
高度抽象,每个Actor作为一个处理逻辑的最小单元,接收各种消息,进行处理并将处理结果发送给另外的Actor
整个系统看起来就是各种Actor在做自己的事情并互相发消息的过程,隐藏了使用线程时的各种细节
可以将Actor看作是比线程资源更微小的处理单元
可以放心的启动成千上万个Actor,具体Actor的处理调度由自身的Dispatcher完成,不用担心过渡的消耗线程资源
全异步&高吞吐量
Local ActorSystem 将消息放到 对应 Actor的Mailbox
Remote消息的发送 依赖 NIO
尽量不要在Actor的Receive方法里边进行阻塞调用,避免降低CPU的使用率,推荐的方式就是全异步处理
可能阻塞的调用,最好通过异步的消息发送给另外的处理单元,当前Actor的Receive处理过程完成,释放线程资源,
另外的Actor在处理完成后将消息异步的发送回当前的Actor进行接下来的处理,减少线程等待的时间
弹性的,可用来构建分布式系统
Akka提供 Cluster Stream等更高层次的抽象
包含DistributedPubSub/Cluster Singleton/Cluster Distributed Data
集群级别的router,balance loader等解决方案
Actor 缺点
高层次的抽象 损失了部分性能
最小的调度级别只是线程
计算密集型的任务推荐从线程的角度去构建,而不是依赖于Actor Model
轻量级分布式任务调度系统 ,Actor Model 负责服务拓扑,事件流转,底层的密集计算,直接通过操作线程资源来实现
不方便调试
同步调用 调用堆栈
事件驱动 顺序
go channel 实例
GO多线程异步处理实例
GO箴言 goproverbs
学习GO要了解的几个特性
akka简介
akka actor demo
netty高性能之道
netty性能优化点
Netty和Akka的区别
上一篇
下一篇
一站式大数据平台StreamX
Spark 累加器 Accumulator
scala future 实例
Scala 柯里化 Currying
scala 方法和函数的区别
scala 学的走火入魔