Apache camel 驼峰jms无法从IBM MQ获取消息

Apache camel 驼峰jms无法从IBM MQ获取消息,apache-camel,ibm-mq,Apache Camel,Ibm Mq,我有几个camel微服务作为单独的war文件部署到tomcat。每个war文件都包含一个唯一的驼峰路由。其中一个服务接受soap请求并将消息放入IBM MQ上的队列。这是毫无问题的。获取这些消息的服务似乎不会将消息从队列中拉出来并在队列中转发。每个war文件都有以下内容作为其IBM MQ配置 <!-- Configure IBM MQ connection factory --> <bean id="ibmMqConnectionFactory" class="c

我有几个camel微服务作为单独的war文件部署到tomcat。每个war文件都包含一个唯一的驼峰路由。其中一个服务接受soap请求并将消息放入IBM MQ上的队列。这是毫无问题的。获取这些消息的服务似乎不会将消息从队列中拉出来并在队列中转发。每个war文件都有以下内容作为其IBM MQ配置

   <!-- Configure IBM MQ connection factory -->
    <bean id="ibmMqConnectionFactory" class="com.ibm.mq.jms.MQConnectionFactory">
        <property name="transportType" value="1"/>
        <property name="hostName"      value="${ibm.mq.host}"/>
        <property name="port"          value="${ibm.mq.port}"/>
        <property name="channel"       value="${ibm.mq.channel}"/>
        <property name="queueManager"  value="${ibm.qm.name}"/>
    </bean>

    <bean id="ibmMqPooledConnectionFactory" class="org.apache.activemq.jms.pool.PooledConnectionFactory" init-method="start" destroy-method="stop">
        <property name="connectionFactory"                 ref="ibmMqConnectionFactory"/>
        <property name="maxConnections"                    value="8"/>
        <property name="maximumActiveSessionPerConnection" value="1"/>
        <property name="expiryTimeout"                     value="30000"/>
        <property name="idleTimeout"                       value="30000"/>
        <property name="blockIfSessionPoolIsFull"          value="false"/>
    </bean>

    <bean id="ibmMqConnectionFactorySecured" class="org.springframework.jms.connection.UserCredentialsConnectionFactoryAdapter">
        <property name="targetConnectionFactory" ref="ibmMqPooledConnectionFactory"/>
        <property name="username"                value="${ibm.mq.username}"/>
        <property name="password"                value="${ibm.mq.password}"/>
    </bean>

    <bean id="ibmMqTransactionManager" class="org.springframework.jms.connection.JmsTransactionManager">
        <property name="connectionFactory" ref="ibmMqConnectionFactorySecured" />
    </bean>

    <bean id="ibmMqJmsConfig" class="org.apache.camel.component.jms.JmsConfiguration">
        <property name="connectionFactory"   ref="ibmMqConnectionFactorySecured"/>
        <property name="concurrentConsumers" value="4"/>
        <property name="transacted"          value="true"/>
        <property name="transactionManager"  ref="ibmMqTransactionManager" />
        <property name="cacheLevelName"      value="CACHE_NONE" />
    </bean>

    <bean id="ibmMq" class="org.apache.camel.component.jms.JmsComponent">
        <property name="configuration" ref="ibmMqJmsConfig"/>
    </bean>

拉取队列消息的驼峰路由之一的示例如下所示

<route id="cancellation-service-route" errorHandlerRef="deadLetterErrorHandler">
    <from uri="{{cancellationService.queue}}"/>
    <unmarshal ref="requestCancellationRequest"/>
    <to uri="bean:cancellationTranslator?method=transform"/>
    ...
</route>

...

路由启动,但不会将消息从队列中拉出。

在将消息发送到队列之前,我通过执行
解决了截断问题。我怀疑这是因为该消息是UTF-8 ecoded xml消息

我发现放入队列的消息正在被截断。这会导致侦听器失败。我不知道为什么邮件会被截断。当使用ActiveMQ时,它可以正常工作。maximumActiveSessionPerConnection=1似乎很低。你能试试更高的值吗,比如20?关于被截断的消息:我记得一些WMQ工具只显示被截断的消息。这可能会误导你,谢谢你,塞巴斯蒂安。在将消息发送到队列之前,我通过这样做解决了截断问题。我怀疑这是因为该消息是UTF-8 ecoded xml消息。奇怪的是,我在使用ActiveMQ时不必这样做