6.2. publish-Subscribe Channel
概述 复制链接链接已复制到粘贴板!
发布订阅频道 (如 图 6.2 “发布订阅频道模式” 所示)是一个 第 5.2 节 “消息频道”,它可让多个订阅者消耗任何给定消息。这与 第 6.1 节 “point-to-Point 频道” 相反。发布订阅通道经常用作向多个订阅者广播事件或通知的方法。
图 6.2. 发布订阅频道模式
支持发布订阅频道的组件 复制链接链接已复制到粘贴板!
以下 Apache Camel 组件支持发布订阅频道模式:
JMS 复制链接链接已复制到粘贴板!
在 JMS 中,发布订阅通道由 主题 表示。例如,您可以指定名为 StockQuotes
的 JMS 主题的端点 URI,如下所示:
jms:topic:StockQuotes
jms:topic:StockQuotes
如需了解更多详细信息,请参阅 Apache Camel 组件参考指南 中的 Jms。
ActiveMQ 复制链接链接已复制到粘贴板!
在 ActiveMQ 中,发布订阅通道由主题表示。例如,您可以为名为 StockQuotes
的 ActiveMQ 主题指定端点 URI,如下所示:
activemq:topic:StockQuotes
activemq:topic:StockQuotes
如需了解更多详细信息,请参阅 Apache Camel 组件参考指南 中的 ActiveMQ。
XMPP 复制链接链接已复制到粘贴板!
XMPP (Jabber)组件在组通信模式中使用时支持发布订阅频道模式。如需了解更多详细信息,请参阅 Apache Camel 组件参考指南 中的 Xmpp。
静态订阅列表 复制链接链接已复制到粘贴板!
如果您愿意,您也可以在 Apache Camel 应用程序本身中实施发布订阅逻辑。简单的方法是定义一个 静态订阅列表,其中目标端点在路由末尾都明确列出。但是,这种方法不像 JMS 或 ActiveMQ 主题而灵活。
Java DSL 示例 复制链接链接已复制到粘贴板!
以下 Java DSL 示例演示了如何使用单个发布程序 seda:a
,以及三个订阅者,seda:b
、seda:c
、seda:c 和 seda:d
模拟发布订阅频道:
from("seda:a").to("seda:b", "seda:c", "seda:d");
from("seda:a").to("seda:b", "seda:c", "seda:d");
这仅适用于 InOnly 消息交换模式。
XML 配置示例 复制链接链接已复制到粘贴板!
以下示例演示了如何在 XML 中配置相同的路由: