【问题标题】:Spring Access JMS on remote server远程服务器上的 Spring Access JMS
【发布时间】:2019-06-08 11:52:55
【问题描述】:

我有一个 Maven Spring 4 应用程序,我在 http://localhost:9292 的本地 Jetty 服务器上运行。 我还有一个在 http://localhost:9990 运行的 JBoss EAP 服务器,我在上面创建了一个 JMS 主题。

但我不知道如何从我的 Spring 应用程序访问 JMS 元素。

本文末尾是 JBoss EAP 7 配置文件standalone.xml 中的一些元素,(消息部分)

这是我尝试从我的 Spring 应用程序至少访问连接工厂的方法

final Properties env = new Properties();
env.put(Context.PROVIDER_URL, "remote://http://localhost:9990");

Context context = new InitialContext(env);
ConnectionFactory cf = (ConnectionFactory) context.lookup("RemoteConnectionFactory");

但我有一个错误:

javax.naming.NameNotFoundException;剩下的名字 '远程连接工厂'

你知道我可以如何使用远程 JMS 元素,如 ConnectionFactory、Topic、...

提前感谢您的帮助

<subsystem xmlns="urn:jboss:domain:messaging-activemq:1.0">
    <server name="default">
        <cluster password="${jboss.messaging.cluster.password:CHANGE ME!!}"/>
        <security-setting name="#">
            <role name="guest" delete-non-durable-queue="true" create-non-durable-queue="true" consume="true" send="true"/>
        </security-setting>
        <address-setting name="#" redistribution-delay="1000" message-counter-history-day-limit="10" page-size-bytes="2097152" max-size-bytes="10485760" expiry-address="jms.queue.ExpiryQueue" dead-letter-address="jms.queue.DLQ"/>
        <http-connector name="http-connector" endpoint="http-acceptor" socket-binding="http"/>
        <http-connector name="http-connector-throughput" endpoint="http-acceptor-throughput" socket-binding="http">
            <param name="batch-delay" value="50"/>
        </http-connector>
        <in-vm-connector name="in-vm" server-id="0"/>
        <http-acceptor name="http-acceptor" http-listener="default"/>
        <http-acceptor name="http-acceptor-throughput" http-listener="default">
            <param name="batch-delay" value="50"/>
            <param name="direct-deliver" value="false"/>
        </http-acceptor>
        <in-vm-acceptor name="in-vm" server-id="0"/>
        <broadcast-group name="bg-group1" connectors="http-connector" jgroups-channel="activemq-cluster"/>
        <discovery-group name="dg-group1" jgroups-channel="activemq-cluster"/>
        <cluster-connection name="my-cluster" discovery-group="dg-group1" connector-name="http-connector" address="jms"/>
        <jms-queue name="ExpiryQueue" entries="java:/jms/queue/ExpiryQueue"/>
        <jms-queue name="DLQ" entries="java:/jms/queue/DLQ"/>
        <jms-topic name="my_topic" entries="java:/jms/topic/my_topic"/>
        <connection-factory name="InVmConnectionFactory" entries="java:/ConnectionFactory" connectors="in-vm"/>
        <connection-factory name="RemoteConnectionFactory" reconnect-attempts="-1" block-on-acknowledge="true" ha="true" entries="java:jboss/exported/jms/RemoteConnectionFactory" connectors="http-connector"/>
        <pooled-connection-factory name="activemq-ra" transaction="xa" entries="java:/JmsXA java:jboss/DefaultJMSConnectionFactory" connectors="in-vm"/>
    </server>
</subsystem>

套接字绑定部分:

<socket-binding-group name="standard-sockets" default-interface="public" port-offset="${jboss.socket.binding.port-offset:0}">
    <socket-binding name="management-http" interface="management" port="${jboss.management.http.port:9990}"/>
    <socket-binding name="management-https" interface="management" port="${jboss.management.https.port:9993}"/>
    <socket-binding name="ajp" port="${jboss.ajp.port:8009}"/>
    <socket-binding name="http" port="${jboss.http.port:8080}"/>
    <socket-binding name="https" port="${jboss.https.port:8443}"/>
    <socket-binding name="iiop" interface="unsecure" port="3528"/>
    <socket-binding name="iiop-ssl" interface="unsecure" port="3529"/>
    <socket-binding name="jgroups-mping" interface="private" port="0" multicast-address="${jboss.default.multicast.address:230.0.0.4}" multicast-port="45700"/>
    <socket-binding name="jgroups-tcp" interface="private" port="7600"/>
    <socket-binding name="jgroups-tcp-fd" interface="private" port="57600"/>
    <socket-binding name="jgroups-udp" interface="private" port="55200" multicast-address="${jboss.default.multicast.address:230.0.0.4}" multicast-port="45688"/>
    <socket-binding name="jgroups-udp-fd" interface="private" port="54200"/>
    <socket-binding name="modcluster" port="0" multicast-address="224.0.1.105" multicast-port="23364"/>
    <socket-binding name="txn-recovery-environment" port="4712"/>
    <socket-binding name="txn-status-manager" port="4713"/>
    <outbound-socket-binding name="mail-smtp">
        <remote-destination host="localhost" port="25"/>
    </outbound-socket-binding>
</socket-binding-group>

【问题讨论】:

    标签: jms spring-jms jboss-eap-7


    【解决方案1】:

    我看到了一些错误:

    • 我建议指定初始上下文工厂,例如:

      env.put(Context.INITIAL_CONTEXT_FACTORY, org.jboss.naming.remote.client.InitialContextFactory.class.getName());
      
    • 默认情况下,您的 JNDI 查找应使用 http-remoting://localhost:8080

    • 远程客户端根据服务器端配置中java:jboss/exported/ 之后的内容查找 JNDI 条目。对于您的RemoteConnectionFactory 连接工厂,您应该在查找中使用jms/RemoteConnectionFactory,例如:

      ConnectionFactory cf = (ConnectionFactory) context.lookup("jms/RemoteConnectionFactory");
      
    • 如果您想从远程客户端查找 my_topic 主题,您需要添加一个远程公开 JNDI 名称的条目,例如:

      <jms-topic name="my_topic" entries="java:/jms/topic/my_topic java:jboss/exported/jms/topic/my_topic"/>
      

    【讨论】:

    • 感谢您的回答。现在我在第一次查找时遇到错误:javax.naming.NamingException:无法连接到任何服务器。服务器尝试:[remote://localhost:4447],在添加了您提到的初始上下文工厂之后。我也尝试了 remote://localhost:8080 但结果相同。所以我还在寻找
    • 服务器在运行吗?您是否在与服务器相同的机器上运行客户端?服务器是否配置为使用 JNDI 的默认端口(即 4447)?
    • 是的。两者都在同一台机器上运行。在standalone.xml 文件中,我没有看到任何4447 号码。但我看到 所以我也尝试使用端口 8080。
    • 一位同事建议添加 env.put("jboss.naming.client.connect.options.org.xnio.Options.SASL_POLICY_NOANONYMOUS", "true"); env.put("jboss.naming.client.connect.options.org.xnio.Options.SASL_POLICY_NOPLAINTEXT", "false");
    • 请将您的服务器配置粘贴到原始问题中。
    猜你喜欢
    • 2012-11-12
    • 2014-08-22
    • 1970-01-01
    • 2010-12-20
    • 2016-07-17
    • 1970-01-01
    • 1970-01-01
    • 2012-03-20
    • 2018-12-04
    相关资源
    最近更新 更多