消息处理器中定义的序列未收到响应

Sequence defined in the Message Processor doesn't receive the response

我有一个单独的代理(在 WSO2ESB4.8.1 中),它将消息发送到消息存储(配置为 WSO2MB 2.2.0),然后处理器将消息发送到后端,后端接收消息,但来自后端的响应不会返回处理器中定义的序列,Seq_IfcFileCheckinResponse

我的后端是休息服务,我正在发送 json 请求。 我在 esb 控制台中注意到以下警告消息,

WARN - JmsConsumer [JMSMessageStore-C-1]. Did not receive a javax.jms.ObjectMessage

消息存储和处理器配置如下,

 <messageStore class="org.apache.synapse.message.store.impl.jms.JmsStore"
                 name="JMSMessageStore">
      <parameter name="java.naming.factory.initial">org.wso2.andes.jndi.PropertiesFileInitialContextFactory</parameter>
      <parameter name="store.jms.password">admin</parameter>
      <parameter name="java.naming.provider.url">repository/conf/jndi.properties</parameter>
      <parameter name="store.jms.connection.factory">QueueConnectionFactory</parameter>
      <parameter name="store.jms.username">admin</parameter>
      <parameter name="store.jms.destination">IfcQueue</parameter>
      <parameter name="store.jms.JMSSpecVersion">1.1</parameter>
   </messageStore>

   <messageProcessor class="org.apache.synapse.message.processor.impl.forwarder.ScheduledMessageForwardingProcessor"
                     name="JMSMessageProcessor"
                     targetEndpoint="bimserverendpoint"
                     messageStore="JMSMessageStore">
      <parameter name="message.processor.reply.sequence">Seq_IfcFileCheckinResponse</parameter>
      <parameter name="client.retry.interval">5000</parameter>
      <parameter name="max.delivery.attempts">2</parameter>
      <parameter name="interval">1000</parameter>
      <parameter name="message.processor.fault.sequence">ErrorSeq_IfcFileCheckinResponserSeq</parameter>
      <parameter name="is.active">true</parameter>
   </messageProcessor>

您应该验证:

  • 属性 "OUT_ONLY" 未在将消息放入 MessageStore 的代理中设置为 true
  • http 状态代码的值(来自您的后端服务的响应)是 200 或 500(在 ESB 和您的后端服务之间使用 tcpmon 查看响应)

警告 "Did not receive a javax.jms.ObjectMessage" 是在您存储消息时或消息处理器将消息从存储中取出时记录的? (停用您的消息处理器并调用将消息存储在商店中的代理)