Wildfly 8.1在远程JMS ConnectionFactory查找时抛出NameNotFoundException

时间:2015-02-24 03:44:40

标签: java jms wildfly

我遇到一个问题,表面看起来非常简单,但这让我感到难过了几天。

我正在尝试在Wildfly 8.1.0上使用以下jndi名称在服务器上部署JMS连接工厂和队列:

java:jboss/exported/jms/UnicsRetry for the connection factory
java:jboss/exported/queue/Create for the queue

这是我对这两个组件的配置xml位,从我从文档中收集的内容来看,它看起来是正确的:

<connection-factory name="UnicsJmsSource">
       <connectors>
            <connector-ref connector-name="http-connector"/>
       </connectors>
       <entries>
              <entry name="java:jboss/exported/jms/UnicsRetry"/>
      </entries>
     <compress-large-messages>false</compress-large-messages>
     <failover-on-initial-connection>false</failover-on-initial-connection>
     <use-global-pools>true</use-global-pools>
 </connection-factory>

 <jms-queue name="CreateQueue">
     <entry name="java:jboss/exported/queue/Create"/>
     <durable>true</durable>
 </jms-queue>

Wildfly本身接受这些并且顺利启动(使用命令行中的独立完整xml),但是当我尝试通过JNDI访问连接工厂时(使用此提供程序URL:http-remoting:// localhost:8080)使用jboss命名远程客户端上下文工厂)我总是得到一个名称未找到异常。

我去打印出java:global和java:jboss的jndi绑定,如下所示:

context.listBindings("java:global"); 

在这两种情况下我都得到了这个输出

jboss/exported/jms/UnicsRetry -- service jboss.naming.context.java.jboss.exported.jboss.exported.jms.UnicsRetry

看起来连接工厂实际上是绑定的,为什么查找失败呢?不用说,我还没有能够尝试队列本身或我真正想要测试的MDB。我认为可能是我必须删除java:jndi的一部分,当进行查找时,如列表显示,但它也不起作用。

如果它与我的问题有任何关系,我不得不在我的pom.xml中建立这些依赖项来构建我的测试客户端:

<dependency>
   <groupId>org.jboss</groupId>
   <artifactId>jboss-remote-naming</artifactId>
   <version>2.0.1.Final</version>
</dependency>
<dependency>
   <groupId>org.jboss.xnio</groupId>
   <artifactId>xnio-nio</artifactId>
   <version>3.3.0.Final</version>
</dependency>

这是我从独立客户端和Mule JMS连接器获得的完整堆栈跟踪。

Exception in thread "main" javax.naming.NameNotFoundException: jboss/exported/jms/UnicsRetry -- service jboss.naming.context.java.jboss.exported.jboss.exported.jms.UnicsRetry
    at org.jboss.as.naming.ServiceBasedNamingStore.lookup(ServiceBasedNamingStore.java:104)
    at org.jboss.as.naming.NamingContext.lookup(NamingContext.java:202)
    at org.jboss.as.naming.NamingContext.lookup(NamingContext.java:179)
    at org.jboss.naming.remote.protocol.v1.Protocol$1.handleServerMessage(Protocol.java:127)
    at org.jboss.naming.remote.protocol.v1.RemoteNamingServerV1$MessageReciever$1.run(RemoteNamingServerV1.java:73)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)

任何类型的读者可以提供的任何帮助都将非常感激,这让我把头发拉了出来。

1 个答案:

答案 0 :(得分:0)

我用来连接JMS资源的String是一个错误。当JNDI是远程的时,连接要求您删除JNDI的java:jboss / exported部分。