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

时间:2016-09-09 07:18:05

标签: java ibm-mq

我在Windows 7中安装了IBM MQ V7.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)

任何人都可以告知连接失败的原因。 我是否需要在队列管理器上启用远程管理?

以下是我用于连接的代码片段

public void init(){
    MQEnvironment.hostname = hostName;
    MQEnvironment.port = Integer.valueOf(port);
    MQEnvironment.channel = serverChannelName;
    MQEnvironment.properties.put(MQC.TRANSPORT_PROPERTY, MQC.TRANSPORT_MQSERIES);
    LOGGER.info("queueManagerName: " + queueManagerName);
    LOGGER.info("hostName: " + hostName);
    LOGGER.info("serverChannelName: " + serverChannelName);
    LOGGER.info("port: " + port);
    //initialize the connection pool
    MQPoolToken token = MQEnvironment.addConnectionPoolToken();
    try {
        mqQueueManager = new MQQueueManager(queueManagerName, MQEnvironment.properties);
        LOGGER.info("mqQueueManager: " + mqQueueManager);
    } catch (MQException e) {
        LOGGER.error(e.getMessage(), e);
    }
}

3 个答案:

答案 0 :(得分:2)

MQRC 2035是MQRC_NOT_AUTHORIZED。返回的原因可以在队列管理器上的AMQERR日志中找到。

由于CHLAUTH尚未配置,并且默认情况下处于打开状态,因此我预计您无法连接,因为您没有通过CHLAUTH规则。

答案 1 :(得分:1)

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

mqrc 2035 returns MQRC_NOT_AUTHORIZED

其中一个原因可能是权限。这可以通过在QueueManager(setmqaut)上设置正确的权限来解决,然后在通道上启用用户连接到MQ以按照here所述进行授权。发布此信息后,您可以通过将userId添加到MQEnvironment来使用代码进行连接,然后转到

您也可以参考此technote获取相关信息。

答案 2 :(得分:0)

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

SET CHLAUTH('CNL_NAME')TYPE(BLOCKUSER)USERLIST(ALLOWANY)

ALTER QMGR 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。