Vertx中的verticle详解

Vertx中有三类verticle

1,Standard verticles:标准Verticles

1,Standard Verticle会被分派到一个event loop线程上,
2,该Standard Verticle里面注册的所有回调handler都会被这个event loop线程来调用

也就是说,Standard verticle从属于一个event loop线程,无论有多少请求处理,都只会被 这个event loop线程来处理。
假设Standard verticle中有一个处理handler,需要处理每秒1000个请求,由于只有一个event loop线程可以用,所以这个处理handler必须要在1/1000秒内处理一个请求才能达到要求。当请求量远远多于1000时,就会造成event loop线程的堵塞,导致异常发生。

写法:

Verticle myVerticle = new MyVerticle();
vertx.deployVerticle(myVerticle);

2,Worker verticles:工作Verticles

1,Worker Verticle会被(worker thread pool)线程池中的一个线程来执行,只限于执行,执行之后,Worker Verticle不会从属于这个worker thread
2,该Worker Verticle里面注册的回调handler有可能会被(worker thread pool)线程池中的任意一个空闲的线程执行
3,Worker Verticle的实例在一个时间点只会被一个线程来执行,不会在同一个时间有两个线程同时执行一个Worker Verticle实例

也就是说,和Standard verticle相比:
1,Worker verticles不会阻塞event loop线程
2,因为同一个时间点,也只有一个实例会被运行,所以也不会增加并发的吞吐量

适用场景:
1,比如说一个回调handler需要3/1000秒来处理,每秒有1000个并发请求,如果适用Standard verticle的话,就会造成event loop线程的阻塞(默认阻塞时间为2s)。这种场景就需要适用Worker verticles来处理了。
2,本身回调handler就需要很长时间的处理,比如复杂算法,存取DB大量数据,以及耗时的IO操作。

写法:

DeploymentOptions options = new DeploymentOptions().setWorker(true);
vertx.deployVerticle(new MyVerticle(), options);

3,Multi-threaded worker verticles:多线程-工作Verticles

和普通的Worker verticles相比,唯一的区别在于,Multi-threaded worker verticles会在同一个时间点,有多个线程同时执行一个Worker Verticle实例

所以说,必须要求Verticle实例要考虑线程安全,属于高危写法,不建议适用

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值