vert.x(vertx)core--verticle和Event Bus

1 篇文章 0 订阅

Standard verticles 只属于一个线程,只能被一个线程执行;
Worker verticles 在同一时间只能被一个线程执行,但是不同的时间可以被其他线程执行。
和普通的Worker verticles相比,唯一的区别在于,Multi-threaded worker verticles会在同一个时间点,有多个线程同时执行一个Worker Verticle实例。
所以说,必须要求Verticle实例要考虑线程安全,属于高危写法,不建议适用。

Event Bus(事件总线) 是Vert.x的神经系统,负责应用系统消息的传递。
Vert.x各模块(Verticle)之间的相互调用就是通过Event Bus实现的。
最简单的发布方法接收一个地址,和一个Object类型的消息对象:

@Fluent
EventBus publish(String address, Object message);

这种方式发布的消息,所有订阅到address的消费者都能够收到消息,这也就是发布-订阅模式。
还有一种是点对点模式,这种模式发布的消息只能有一个消费者收到:

@Fluent
<T> EventBus send(String address, Object message,
 DeliveryOptions options, Handler<AsyncResult<Message<T>>> replyHandler);

对于订阅消息比较简单,只有一个方法,就是consumer,方法的声明如下:

<T> MessageConsumer<T> consumer(String address, Handler<Message<T>> handler);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值