javax.jms.JMSException:向JBoss EAP 7.2中的嵌入式ActiveMQ Artemis发送消息时未能创建会话工厂

javax.jms.JMSException:向JBoss EAP 7.2中的嵌入式ActiveMQ Artemis发送消息时未能创建会话工厂,java,jms,activemq-artemis,jboss-eap-7,Java,Jms,Activemq Artemis,Jboss Eap 7,我正在尝试开发一个程序,将消息发送到JBoss EAP 7.2中嵌入的ActiveMQ Artemis。我已按照以下说明进行操作: 下面是我发送消息的方法: 公共无效发送消息{ Context=null; ConnectionFactory=null; 目的地=空; 连接=空; 会话=空; MessageProducer=null; Properties initialProperties=新属性; initialProperties.putInitialContext.INITIAL\u CO

我正在尝试开发一个程序,将消息发送到JBoss EAP 7.2中嵌入的ActiveMQ Artemis。我已按照以下说明进行操作:

下面是我发送消息的方法:

公共无效发送消息{ Context=null; ConnectionFactory=null; 目的地=空; 连接=空; 会话=空; MessageProducer=null; Properties initialProperties=新属性; initialProperties.putInitialContext.INITIAL\u CONTEXT\u工厂, org.wildfly.naming.client.WildFlyInitialContextFactory; initialProperties.putInitialContext.PROVIDER_URL,http remoting://:8080; initialProperties.putContext.SECURITY_主体,mquser; initialProperties.putContext.SECURITY\u凭据,Mquser@123; 试一试{ 上下文=新的InitialContextinitialProperties; factory=QueueConnectionFactoryContext.lookupjms/RemoteConnectionFactory; System.out.printlnookup成功; destination=destination context.lookupjms/queue/TestQueue; System.out.printlnQueue查找成功; connection=factory.createConnection; 会话=connection.createSessionfalse,session.AUTO\u确认; producer=session.createProducerdestination; 字符串文本=测试消息; TextMessage TextMessage=session.createTextMessage; textMessage.setTexttext; 连接启动; System.out.println将要发送; producer.sendtextMessage; System.out.printlnith.getClass.getName+已发送消息:+text; }捕获NamingE异常{ e、 打印跟踪; }抓捕JME{ e、 打印跟踪; }最后{ 如果上下文!=null{ 试一试{ 上下文。关闭; }捕获NamingException{ 例如,打印跟踪; } } 如果连接!=null{ 试一试{ 连接。关闭; }性变态{ 例如,打印跟踪; } } } } 我已使用密码创建了应用程序用户mquserMquser@123. 我已禁用standalone-full.xml中的安全性。以下是standalone-full.xml中消息传递子系统的外观:

下面是standalone-full.xml的和部分

<interfaces>
    <interface name="management">
        <inet-address value="${jboss.bind.address.management:127.0.0.1}"/>
    </interface>
    <interface name="public">
        <inet-address value="${jboss.bind.address:127.0.0.1}"/>
    </interface>
    <interface name="unsecure">
        <inet-address value="${jboss.bind.address.unsecure:127.0.0.1}"/>
    </interface>
</interfaces>
<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="txn-recovery-environment" port="4712"/>
    <socket-binding name="txn-status-manager" port="4713"/>
    <socket-binding name="iiop" interface="unsecure" port="3528"/>
    <socket-binding name="iiop-ssl" interface="unsecure" port="3529"/>
    <outbound-socket-binding name="mail-smtp">
        <remote-destination host="localhost" port="25"/>
    </outbound-socket-binding>
</socket-binding-group>
在线路连接中=factory.createConnection;有人能告诉我程序有什么问题吗?环境有什么问题吗?或者可能有什么问题吗?

当启动服务器时使用命令行上的-b开关时,这意味着套接字绑定组中的所有套接字绑定在默认情况下都将绑定到该IP地址

您的JMS客户端正在查找JMS/RemoteConnectionFactory。以下是该连接工厂的配置:

此连接工厂正在使用http连接器。以下是http连接器的配置:

这是使用http套接字绑定,该绑定使用内部IP地址,因为您在启动服务器时使用命令行上的-b开关。因此,当您的远程JMS客户端查找JMS/RemoteConnectionFactory时,它将获得一个指向内部IP地址的连接工厂,该地址将失败

要解决此问题,您需要将RemoteConnectionFactory配置为使用外部IP地址

首先,定义一个新接口,例如:

您可以在这里配置实际的外部IP地址,也可以使用-Djboss.bind.address.external=,在命令行上传递它

其次,定义一个新的套接字绑定以使用此接口:

第三,定义一个新的http连接器以使用此套接字绑定:

第四,将RemoteConnectionFactory更改为使用此http连接器:


@JustinBertram我已经用standalone-full.xml的完整消息子系统部分更新了我的问题。还需要什么吗?@JustinBertram我已经添加了standalone-full.xml的and部分,以及我用来启动jboss的命令。请注意,在启动jboss时,我使用的是服务器的内部IP地址,在JNDI中查找受管对象时,我使用的是服务器的外部IP地址。如果要将服务器绑定到内部IP地址,那么在使用外部IP地址的情况下,JNDI查找是如何工作的?您是否正在进行某种NAT?我不确定网络的详细信息,但已在JNDI中成功查找了ConnectionFactory和队列。只有在创建时才会引发异常
连接对象。我遵循了前面提到的步骤,但是jboss在启动过程中抛出了一个异常。异常表示无法解析接口外部性如果我在接口部分给出内部IP地址私有IP而不是外部IP公共IP,它不会引发任何异常,但我得到了问题中最初发布的错误。这是我必须在网络级别修改的吗?问题得到解决,NAT配置错误,我们需要更改。谢谢我将提出一个关于启用安全性的新问题,因为我无法解决该问题并在standalone-full.xml中禁用安全性仅供参考,我必须添加一个新的出站套接字绑定条目,并在http connector中使用新创建的套接字绑定,如下所示:
sh standalone.sh --server-config=standalone-full.xml -b <<INTERNAL-IP>> -bmanagement <<INTERNAL-IP>>
javax.jms.JMSException: Failed to create session factory
    at org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory.createConnectionInternal(ActiveMQConnectionFactory.java:846)
    at org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory.createConnection(ActiveMQConnectionFactory.java:282)
    at org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory.createConnection(ActiveMQConnectionFactory.java:277)
    at com.mycompany.springdb.service.MessagingService.sendMessage(MessagingService.java:45)
    at com.mycompany.springdb.controller.DateController.sendMessage(DateController.java:68)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:190)
    at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:138)
    at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:105)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:893)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:798)
    at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87)
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1040)
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:943)
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
    at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
    at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:94)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:526)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
    at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:367)
    at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
    at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:860)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1591)
    at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Thread.java:745)
Caused by: ActiveMQNotConnectedException[errorType=NOT_CONNECTED message=AMQ219007: Cannot connect to server(s). Tried with all available servers.]
    at org.apache.activemq.artemis.core.client.impl.ServerLocatorImpl.createSessionFactory(ServerLocatorImpl.java:797)
    at org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory.createConnectionInternal(ActiveMQConnectionFactory.java:844)
    ... 58 more