【问题标题】:SpringBoot JMS Listener: Could not refresh JMS Connection for destinationSpring Boot JMS 侦听器:无法刷新目标的 JMS 连接
【发布时间】:2018-12-19 14:22:07
【问题描述】:

我有 Spring Boot 应用程序,它通过 @JmsListener 注释从组件类中侦听 IBM MQ 队列,如下所示。 MQ 属性(主机名、通道、端口等)从 yaml 文件中设置。

 @JmsListener(destination = "<QueueName>")
 public void receiveMessage(BytesMessage msg) { 
     //snippet to read msg
 }

在gradle build中添加MQ依赖如下,

compile("com.ibm.mq:mq-jms-spring-boot-starter:0.0.2") {  
        exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging'
    }

只要我使用 Tomcat 容器在本地运行应用程序,它就可以正常工作并监听消息。但是如果我将它打包为 EAR 并部署到 Wesbphere8.5 服务器,它会抛出异常,并且侦听器不会从队列中读取消息。我确认所有运行时依赖项都打包在 EAR 中。尝试了不同版本的 MQ 依赖项,但没有成功。

2018-07-10 15:21:16,531 错误 DefaultMessageListenerContainer - 无法刷新目标“QueueName”的 JMS 连接 - 重试使用 FixedBackOff{interval=5000, currentAttempts=34, 最大尝试=无限}。原因:JMSFMQ6312:发生异常 Java(tm) MQI。嵌套异常是 com.ibm.mq.jmqi.JmqiException: CC=2;RC=2195;AMQ9546:收到错误返回码。 [1=java.lang.reflect.InvocationTargetException[null],3=NativeConstructorAccessorImpl.newInstance0]

需要帮助来解决此问题。

【问题讨论】:

  • 我想您会在队列管理器的AMQERR01.LOG 中获得有关此问题的更多信息。
  • 您解决了这个问题吗?解决办法是什么?

标签: spring-boot ibm-mq spring-jms websphere-8 spring-boot-gradle-plugin


【解决方案1】:

我遇到了类似的问题。发生这种情况的原因是 IBM MQ Connection 与您的 JMS 应用程序缺少配置。就我而言,我遇到了与授权相关的异常,但我为 IBM mq 设置了正确的用户凭据。当我检查 IBM mq 站点时,用户名不同,这不是我在 spring 应用程序中配置的。

#IBM MQ JMS Configuration
ibm.mq.queueManager={QUEUE_MANAGER}
ibm.mq.channel={CHANNEL_NAME}
ibm.mq.connName={HOST_NAME(HOST_PORT)}
ibm.mq.user={USER_NAME}
ibm.mq.password={PASSWORD}

然后,我将以下属性添加到使用队列管理器进行身份验证时使用兼容模式。 在这里,我们覆盖了身份验证模式。 MQ V8 或 V9 的当前维护级别通常不需要这样做,但某些早期级别有时会出错,然后可以将此标志设置为“false

ibm.mq.user-authentication-m-q-c-s-p=false

详情请参考this page

【讨论】:

    猜你喜欢
    • 2021-07-28
    • 2015-02-03
    • 1970-01-01
    • 2019-12-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多