消息处理器中定义的序列未收到响应
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" 是在您存储消息时或消息处理器将消息从存储中取出时记录的? (停用您的消息处理器并调用将消息存储在商店中的代理)
我有一个单独的代理(在 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" 是在您存储消息时或消息处理器将消息从存储中取出时记录的? (停用您的消息处理器并调用将消息存储在商店中的代理)