31.4.2. 使用 JMSDestinationDefinition 注解的 JMS 资源配置


您可以使用 server 资源为本地代理 pooled-connection-factory 创建所需的目的地。

如果 resourceAdapter 元素指向 pooled-connection-factory 名称,并且它在本地代理中定义,例如 /subsystem/messaging-activemq/server=default,则它会在本地 Artemis 代理中创建目的地。

注意

如果您需要在基于 Artemis 的远程代理中创建目的地,则必须在 messaging - activemq 子系统中定义 pooled-connection- factory

如果 @JMSDestinationDefinition 注释 中设置resourceAdapter 元素与 messaging-activemq 子系统中为 服务器 定义的 resourceAdapter 元素匹配,则在此代理中创建目的地,无论 pooled-connection-factory 中的连接器指向本地还是远程 Artemis 代理。

使用 JMSDestinationDefinition 注解配置 JMS 资源
  1. 创建连接器:

    /subsystem=messaging-activemq/remote-connector=remote-amq:add(socket-binding="messaging-remote-throughput")
    Copy to Clipboard Toggle word wrap
  2. 创建池连接工厂:

    /subsystem=messaging-activemq/pooled-connection-factory=activemq-ra-remote:add(entries=["java:/jms/remote-amq/JmsConnectionFactory"],connectors=["remote-amq"])
    Copy to Clipboard Toggle word wrap
  3. ee 子系统定义默认的 JMS 连接工厂:

    /subsystem=ee/service=default-bindings:write-attribute(name=jms-connection-factory, value="java:/jms/remote-amq/JmsConnectionFactory")
    Copy to Clipboard Toggle word wrap
  4. 在应用程序代码中使用 @JMSDestinationDefinition 注释:

    @JMSDestinationDefinition(
        name = "java:/jms/queue/MessageBeanQueue",
        interfaceName = "javax.jms.Queue",
        destinationName = "MessageBeanQueue"
        properties= {
            "management-address=remote-activemq.management"
        }
    )
    Copy to Clipboard Toggle word wrap
返回顶部
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2025 Red Hat