179.3. 注
179.3.1. 使用 ActiveMQ
JMS 组件重复使用 Spring 2 的 JmsTemplate
来发送消息。这不是在非J2EE 容器中使用的理想选择,通常需要 JMS 提供程序中的一些缓存以避免 性能不佳。
如果要将 Apache ActiveMQ 用作消息代理,建议执行以下操作之一:
- 使用 ActiveMQ 组件,该组件经过优化以高效地使用 ActiveMQ
-
在 ActiveMQ 中使用
PoolingConnectionFactory
。
179.3.2. 事务和缓存级别
如果您使用消息并使用事务(transacted=true
),缓存级别的默认设置可能会影响性能。
如果您使用 XA 事务,则无法缓存,因为它可能会导致 XA 事务无法正常工作。
如果您不使用 XA,则应考虑缓存速度,如设置 cacheLevelName=CACHE_CONSUMER
。
通过 Camel 2.7.x,cacheLevelName
的默认设置是 CACHE_CONSUMER
。您需要显式设置 cacheLevelName=CACHE_NONE
。
在 Camel 2.8 以后,cacheLevelName
的默认设置是 CACHE_AUTO
。这个默认会自动检测模式,并相应地将缓存级别设置为:
-
如果
transacted=false
-
如果
transacted=true
因此,您可以说默认设置比较保守。如果您使用非 XA 事务,请考虑使用 cacheLevelName=CACHE_CONSUMER
。
179.3.3. 持久化订阅
如果要使用持久主题订阅,则需要同时指定 clientId
和 durableSubscriptionName
。clientId
的值必须是唯一的,且只能由整个网络中的单个 JMS 连接实例使用。您可能更喜欢使用 虚拟主题 以避免这种限制。有关持久化消息传递的更多背景,此处.
179.3.4. Message Header Mapping
在使用消息标头时,JMS 规范指出标头名称必须是有效的 Java 标识符。因此,请尝试将您的标头命名为有效的 Java 标识符。执行此操作的一个优点是,您可以在 JMS Selector 中使用您的标头(其 SQL92 语法强制使用标头的 Java 标识符语法)。
默认使用映射标头名称的简单策略。策略是替换标头名称中的任何点和连字符,并在从线上发送的 JMS 消息恢复标头名称时反转替换。这意味着什么?不会再丢失在 bean 组件上调用的方法名称,不再丢失 File 组件的文件名标头,以此类推。
在 Camel 中接受标头名称的当前标头名称策略如下:
-
当 Camel 使用消息时,点被
DOT
替换,替换会被反向替换 -
hyphen 被
HYPHEN
替换,当 Camel 使用消息时,替换会被反向替换