Message Bus - 消息总线

Liferay的Message Bus提供服务级别的API,用于组件间的松耦合通信。它支持同步和异步消息传递,适用于索引更新、邮件订阅、调度任务等场景。消息总线包括Message Bus、Destinations、Listeners和Senders四个组件。同步消息传递会等待响应,而异步消息传递则不需要。Message Bus的配置和消息类型可以通过特定文件进行设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Message Bus - 消息总线

Liferay的*消息总线(Message Bus)*是一种服务级API,组件可以用它来发送和接收消息。它提供了消息生产者(producers)和消费者(consumers)之间的松耦合。 消息总线(Message Bus)位于Liferay的全局类加载器中,使每个已部署的Web应用程序都可以访问它。 它不支持远程消息传递,但在启用ClusterLink时,可在集群中发送消息。

以下是消息总线的一些常见用法:

  • 发送消息触发检索索引写入事件
  • 发送订阅电子邮件
  • 在调度程序端点处理消息
  • 运行异步(asynchronous)进程

你可以利用消息总线在plugins之间以及plugins内部发送消息。

在阅读消息总线教程时,你将学习*同步(synchronous)异步(asynchronous)*消息传递,*串行(serial)并行(in-psrallel)*消息调度,以及如何定义消息格式的样式。

在直奔主题之前,你应该首先了解Message Bus系统的体系结构(architecture)。

Liferay’s Message Bus System - Liferay的消息总线系统

Liferay的消息总线系统是处理应用程序之间和应用程序内部通信的解决方案。 但是,在开始使用Message Bus之前,你应该了解Message Bus的结构基础知识。 本教程提供有关Message Bus系统组件的信息,以及可以发送的不同类型的消息。

Message Bus System Components - 消息总线系统组件

消息总线系统包含以下组件:

  • Message Bus(消息总线):管理从消息*sender(发送者)到消息listener(收听者)*的消息传输。
  • Destinations(目的地)listener注册的用来接收消息的地址或端点(endpoint)。
  • Listener(收听者):消费在Destinations收到的消息。 他们接收发送到其注册的Destinations的所有消息。
  • Sender(发送者):调用Message Bus将消息发送到Destinations。

你的服务可以将消息发送到一个或多个destinations,并可以收听一个或多个destination。 下图描绘了这一点。 单个服务既可以是消息发送者,也可以是消息监听者。 例如,在下图中,plugin 2 - Service 3Plugin 5 - Service 7都发送和收听消息。

[外链图片转存失败(img-JVyZo4Cj-1562829682539)(https://dev.liferay.com/documents/12052/832136/msg-bus-system.png/bdcd50b2-1abf-1779-2345-9ca0bca9d08f?version=1.0&t=1537564289954 ‘‘Message Bus System’’)]

Message Types - 消息类型

消息总线支持同步synchronous异步asynchronous消息传递:

  • Synchronous messaging 同步消息传递:发送消息后,发送方会阻塞线程,等待收件人的响应。
  • Asynchronous messaging 异步消息传递:发送消息后,发件人可以继续处理。 发件人可以配置为接收回调(Call-back)或发送且忘记(Send-and-Forget)这两种模式。
    • Call-back 回调:发送者包含call-back destination key,作为响应消息(response message)的destination 。 然后,接收者(listener)通过此response destination将响应消息发送回发送者。
    • Send-and-Forget 发送并忘记:发送者在发送的消息中不包含回调信息。

可以通过以下文件配置Message Bus:

  • WEB-INF/src/META-INF/messaging-spring.xml:指定destinations,listener以及其彼此之间的映射。
  • WEB-INF/web.xml:包含plugin的部署描述符列表。 你需要将messaging-spring.xml添加到此文件中的Spring Configurations中。

Note: portal-impl.jar的内部文件META-INF/messaging-core-spring.xml指定Liferay的默认Message Bus类,默认异步消息发送方类和默认同步消息发送方类。

你可以使用com.liferay.portal.kernel.messaging.Message类或com.liferay.portal.kernel.json.JSONObject类来控制消息类型(Message Type)。 这些类包含在Liferay的portal-service.jar文件中。 Liferay核心服务通常以JSON格式序列化和反序列化。 以下教程中将使用这两种类型的消息类来展示如何实现同步和异步消息传递。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值