使用CCDT + Spring Boot在docker中使用IBM MQ进行MQRC_CLIENT_CONN_ERROR

时间:2019-01-22 12:48:11

标签: spring-boot docker jms ibm-mq spring-jms

我正在使用此官方IBM教程: MQ JMS application development with Spring Boot

并在此docker hub页面上获得了IBM®MQ Advanced for Developers的使用:ibmcom/mq

MQ使用以下命令启动:

docker run --name mq --env LICENSE=accept --env MQ_QMGR_NAME=QM1 --publish 1414:1414 --publish 9443:9443 --detach ibmcom/mq 

它已启动并正在运行,我可以使用连接名称和频道信息连接到它:

ibm.mq.channel: DEV.ADMIN.SVRCONN
ibm.mq.connectionName: localhost(1414)

但是,当我尝试使用CCDT文件连接到它时,出现错误。我使用以下命令获取此CCDT文件:

docker cp <container_id>:/mnt/mqm/data/qmgrs/QM1/@ipcc/AMQCLCHL.TAB <path_to_ccdt_path_on_my_computer>

我已经设置了正确的application.yml属性:

ibm:
  mq:
    ccdtUrl: file://<path_to_ccdt_path_on_my_computer>

但我收到此错误:

com.ibm.msg.client.jms.DetailedJMSException: JMSWMQ2020: Failed to connect to queue manager 'QM1' with connection mode 'Client' and supplied CCDT URL 'AMQCLCHL.TAB', see linked exception for more information.
    at com.ibm.msg.client.wmq.common.internal.Reason.reasonToException(Reason.java:595)
    at com.ibm.msg.client.wmq.common.internal.Reason.createException(Reason.java:215)
    at com.ibm.msg.client.wmq.internal.WMQConnection.<init>(WMQConnection.java:424)
    at com.ibm.msg.client.wmq.factories.WMQConnectionFactory.createV7ProviderConnection(WMQConnectionFactory.java:8475)
    at com.ibm.msg.client.wmq.factories.WMQConnectionFactory.createProviderConnection(WMQConnectionFactory.java:7815)
    at com.ibm.msg.client.jms.admin.JmsConnectionFactoryImpl._createConnection(JmsConnectionFactoryImpl.java:303)
    at com.ibm.msg.client.jms.admin.JmsConnectionFactoryImpl.createConnection(JmsConnectionFactoryImpl.java:236)
    at com.ibm.mq.jms.MQConnectionFactory.createCommonConnection(MQConnectionFactory.java:6016)
    at com.ibm.mq.jms.MQConnectionFactory.createConnection(MQConnectionFactory.java:6041)
    at org.springframework.jms.support.JmsAccessor.createConnection(JmsAccessor.java:196)
    at org.springframework.jms.listener.AbstractJmsListeningContainer.createSharedConnection(AbstractJmsListeningContainer.java:411)
    at org.springframework.jms.listener.AbstractJmsListeningContainer.establishSharedConnection(AbstractJmsListeningContainer.java:379)
    at org.springframework.jms.listener.DefaultMessageListenerContainer.establishSharedConnection(DefaultMessageListenerContainer.java:818)
    at org.springframework.jms.listener.AbstractJmsListeningContainer.doStart(AbstractJmsListeningContainer.java:291)
    at org.springframework.jms.listener.AbstractJmsListeningContainer.start(AbstractJmsListeningContainer.java:276)
    at org.springframework.jms.listener.DefaultMessageListenerContainer.start(DefaultMessageListenerContainer.java:612)
    at org.springframework.jms.config.JmsListenerEndpointRegistry.startIfNecessary(JmsListenerEndpointRegistry.java:242)
    at org.springframework.jms.config.JmsListenerEndpointRegistry.start(JmsListenerEndpointRegistry.java:205)
    at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:182)
    at org.springframework.context.support.DefaultLifecycleProcessor.access$200(DefaultLifecycleProcessor.java:53)
    at org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup.start(DefaultLifecycleProcessor.java:360)
    at org.springframework.context.support.DefaultLifecycleProcessor.startBeans(DefaultLifecycleProcessor.java:158)
    at org.springframework.context.support.DefaultLifecycleProcessor.onRefresh(DefaultLifecycleProcessor.java:122)
    at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:879)
    at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.finishRefresh(ServletWebServerApplicationContext.java:161)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:549)
    at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140)
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:775)
    at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:397)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:316)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1260)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1248)
    at Application.main(Application.java:11)
Caused by: com.ibm.mq.MQException: JMSCMQ0001: IBM MQ call failed with compcode '2' ('MQCC_FAILED') reason '2278' ('MQRC_CLIENT_CONN_ERROR').
    at com.ibm.msg.client.wmq.common.internal.Reason.createException(Reason.java:203)
    ... 31 common frames omitted
Caused by: com.ibm.mq.jmqi.JmqiException: CC=2;RC=2278
    at com.ibm.mq.jmqi.remote.api.RemoteFAP.jmqiConnect(RemoteFAP.java:1688)
    at com.ibm.mq.jmqi.remote.api.RemoteFAP.jmqiConnect(RemoteFAP.java:1273)
    at com.ibm.mq.ese.jmqi.InterceptedJmqiImpl.jmqiConnect(InterceptedJmqiImpl.java:377)
    at com.ibm.mq.ese.jmqi.ESEJMQI.jmqiConnect(ESEJMQI.java:562)
    at com.ibm.msg.client.wmq.internal.WMQConnection.<init>(WMQConnection.java:357)
    ... 30 common frames omitted

官方问题排查在这里:2278 (08E6) (RC2278): MQRC_CLIENT_CONN_ERROR,但是说:

“当指定客户端通道定义表(CCDT)确定通道名称,但找不到表本身时,在Java™应用程序中也会发生。”

但是找到表文件,如果我故意拼写错误的文件名,则会收到FileNotFoundException。

那么,我想念什么?

1 个答案:

答案 0 :(得分:4)

您发现的2278 MQRC_CLIENT_CONN_ERROR是因为应用程序找不到与指定的队列管理器名称匹配的通道。

2540 MQRC_UNKNOWN_CHANNEL_NAME错误是因为通过设置频道QMNAME的{​​{1}}字段,您正在尝试连接到名为SYSTEM.DEF.CLNTCONN的{​​{1}}频道,不存在。


默认情况下,新队列管理器附带一个默认通道表,该通道表位于MQDATA路径下的以下位置:SVRCONN

默认频道表仅包含一个名为SYSTEM.DEF.CLNTCONN的{​​{1}}频道。这只是为了显示新定义的qmgrs/<QMGR_NAME>/@ipcc/AMQCLCHL.TAB通道的默认值。

在队列管理器上,客户端应用程序连接到CLNTCONN通道。在连接的客户端,如果您使用CCDT,则与队列管理器SYSTEM.DEF.CLNTCONN配对的通道类型是CLNTCONN


由于要连接到名为SVRCONN的{​​{1}}通道,因此需要使用名为SVRCONN的{​​{1}}通道定义CCDT。

我建议您不要修改默认的CCDT,而只需创建一个新的CCDT。


您可以使用以下步骤创建CCDT:

CLNTCONN

只需将SVRCONNDEV.ADMIN.SVRCONN的值替换为您要调用CCDT的实际路径和名称,例如,在{{1}中创建一个名为CLNTCONN的CCDT },请使用以下命令:

DEV.ADMIN.SVRCONN

有关显示如何创建CCDT以及MQ如何在CCDT中选择特定通道的更多示例,您可以查看我对Connecting to IBM MQ using CCDT file in JMS的回答。