vertx的Actor模型实现

前言

image

note: Context 与 EventLoop 关系 1 : N ; 每次创建一个vericles或者multi instances
通过EventLoopGroup.next挑出一个EventLoop,所以是1:N关系; context <=> verticle.
总结:
1.verticle和multi Instances总和不超过EventLoopSize,multi verticle在同一个EventLoop的
    Thread上运行加大负担,如果造成线程阻塞会影响延时任务(Timer,Periodic)的进行和任务事件堆积过大;
2.verticle中一般可以不用考虑线程(单线程)安全问题,除了定义static variable、static block、
  static method外,verticle之间通过EventBus通信,极端情况本地的verticle之间通过共享内存通信效果更好.
3.每創建一個verticle會根據 setting verticle Type 創建context instance , 所以create verticles size
    > EventloopSize , 那麼一個Eventloop就會執行 multi verticle handlers.

 

Context Class diagram 如图:

image

Verticle Types:

Verticle Types : 一、Standard Verticles、二、Worker Verticles、三、Multi-threaded worker verticles.
本质还是eventloop处理connection、read/write、encode/decode 等等, 事件处理(EventHandler)的逻辑
就在 setting verticle type 处理(Thread), 调度逻辑在VertxHandler类配置的context调度,
和vertx.executeBlocking->{...} 相同效果.

 

调度框图

 

时序图

image

Multi instances Verticle Structure

image

转载于:https://www.cnblogs.com/cmfa/p/10621177.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值