从Java客户端连接到IBM MQ失败,MQJE001:完成代码';2';,原因';2035年&x27年;

从Java客户端连接到IBM MQ失败,MQJE001:完成代码';2';,原因';2035年&x27年;,java,ibm-mq,Java,Ibm Mq,我在windows 7中安装了IBM MQ 7.5版。我使用以下命令创建了一个队列管理器、通道和侦听器 //CREATE THE QUEUE MANAGER crtmqm.exe PG3RT1 //START THE QUEUE MANAGER AS INTERACTIVE strmqm.exe -si PG3RT1 //CONNECT AS SCRIPT CONSOLE runmqsc.exe PG3RT1 //CREATE THE CHANNEL TO APPLICATION CONN

我在windows 7中安装了IBM MQ 7.5版。我使用以下命令创建了一个队列管理器、通道和侦听器

//CREATE THE QUEUE MANAGER
crtmqm.exe PG3RT1

//START THE QUEUE MANAGER AS INTERACTIVE
strmqm.exe -si PG3RT1

//CONNECT AS SCRIPT CONSOLE
runmqsc.exe PG3RT1

//CREATE THE CHANNEL TO APPLICATION CONNECTIVITY
DEFINE CHANNEL(PG3RT1.CHANNEL) CHLTYPE(SVRCONN) TRPTYPE(TCP)

//CREATE THE LISTENER 
DEFINE LISTENER(LISTENER.PG3RT1) TRPTYPE(TCP) PORT(1414)

//START THE LISTENER
START LISTENER(LISTENER.PG3RT1)
现在,我正尝试使用以下java客户机连接到队列管理器。 连接被拒绝,出现以下错误

    15:06:52.175 [localhost-startStop-1] ERROR c.b.c.s.s.m.MQUtil - MQJE001: Completion Code '2', Reason '2035'.
com.ibm.mq.MQException: MQJE001: Completion Code '2', Reason '2035'.
        at com.ibm.mq.MQManagedConnectionJ11.<init>(MQManagedConnectionJ11.java:230)
        at com.ibm.mq.MQClientManagedConnectionFactoryJ11._createManagedConnection(MQClientManagedConnectionFactoryJ11.java:553)
        at com.ibm.mq.MQClientManagedConnectionFactoryJ11.createManagedConnection(MQClientManagedConnectionFactoryJ11.java:593)
        at com.ibm.mq.StoredManagedConnection.<init>(StoredManagedConnection.java:96)
        at com.ibm.mq.MQSimpleConnectionManager.allocateConnection(MQSimpleConnectionManager.java:198)
        at com.ibm.mq.MQQueueManagerFactory.obtainBaseMQQueueManager(MQQueueManagerFactory.java:893)
        at com.ibm.mq.MQQueueManagerFactory.procure(MQQueueManagerFactory.java:780)
        at com.ibm.mq.MQQueueManagerFactory.constructQueueManager(MQQueueManagerFactory.java:729)
        at com.ibm.mq.MQQueueManagerFactory.createQueueManager(MQQueueManagerFactory.java:177)
        at com.ibm.mq.MQQueueManager.<init>(MQQueueManager.java:745)
        at com.bcs.cas.sach.simulator.mq.MQUtil.init(MQUtil.java:52)
        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)

这很可能是一个授权问题。最简单的方法是查看返回代码并进行解释

mqrc 2035返回mqrc\u NOT\u AUTHORIZED

其原因之一可能是权限。这可以通过在QueueManager(setmqaut)上设置正确的权限,然后在通道上启用连接到MQ的用户进行授权来解决,如所述。在此之后,您可以通过将userId添加到MQEnvironment和go来使用代码进行连接


您也可以参考此信息。

这很可能是授权问题。最简单的方法是查看返回代码并进行解释

mqrc 2035返回mqrc\u NOT\u AUTHORIZED

其原因之一可能是权限。这可以通过在QueueManager(setmqaut)上设置正确的权限,然后在通道上启用连接到MQ的用户进行授权来解决,如所述。在此之后,您可以通过将userId添加到MQEnvironment和go来使用代码进行连接


您也可以参考此信息。

MQRC 2035未经MQRC\u授权。返回此消息的原因可以在队列管理器上的AMQERR日志中找到


由于CHLAUTH尚未配置,并且默认情况下处于启用状态,我希望您无法连接,因为您没有通过CHLAUTH规则。

MQRC 2035是MQRC\u未授权的。返回此消息的原因可以在队列管理器上的AMQERR日志中找到


由于CHLAUTH尚未配置,并且默认情况下处于启用状态,我希望您无法连接,因为您没有传递CHLAUTH规则。

我们正在使用runmqsc清除manager上的身份验证设置:

设置CHLAUTH('CNL_NAME')类型(BLOCKUSER)用户列表(ALLOWANY)

更改QMGR CONNAUTH(“”)

刷新安全类型(CONNAUTH)

在开发的情况下。或正确设置凭据:

QueueConnectionFactory.createQueueConnection(props.get(PROP.USER), props.get(PROP.PASSWD));
对于JMS或:

...
MQEnvironment.userID = uid;
MQEnvironment.password = passwd;
new MQQueueManager(isQueueMgr);

对于本机com.ibm.mq.MQQueueManager。

我们使用runmqsc清除管理器上的身份验证设置:

设置CHLAUTH('CNL_NAME')类型(BLOCKUSER)用户列表(ALLOWANY)

更改QMGR CONNAUTH(“”)

刷新安全类型(CONNAUTH)

在开发的情况下。或正确设置凭据:

QueueConnectionFactory.createQueueConnection(props.get(PROP.USER), props.get(PROP.PASSWD));
对于JMS或:

...
MQEnvironment.userID = uid;
MQEnvironment.password = passwd;
new MQQueueManager(isQueueMgr);

对于本机com.ibm.mq.MQQueueManager。

错误的详细信息应在mq错误日志中。您也可以提供吗?原因代码(v8.0):错误的详细信息应该在MQ错误日志中。您也可以提供吗?原因代码(v8.0):谢谢您的回复。队列管理器中默认启用了CHLAUTH。我禁用了CHLAUTH,现在我可以连接了。谢谢你的回复。队列管理器中默认启用了CHLAUTH。我禁用了CHLAUTH,现在我可以连接了。