0

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

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

警告 - JmsConsumer [JMSMessageStore-C-1]。没有收到 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>
4

1 回答 1

1

您应该验证:

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

当您存储消息或消息处理器将其从存储中出列时,会记录警告“未收到 javax.jms.ObjectMessage”?(停用您的消息处理器并调用将消息存储在商店中的代理)

于 2015-05-26T07:14:49.953 回答