我有一个单独的代理(在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>
and
<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>
您应该验证:
- 在将消息放入 MessageStore 的代理中,属性“OUT_ONLY”未设置为 true
- http 状态代码的值(来自后端服务的响应)是 200 或 500(在 ESB 和后端服务之间使用 tcpmon 查看响应)
当您存储消息或消息处理器将其从存储中出队时,会记录警告“未收到 javax.jms.ObjectMessage”吗? (停用您的消息处理器并调用将消息存储在商店中的代理)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)