我已经在WSO2 ESB 4.7.0中使用事务和CLIENT_ACKNOWLEDGE配置了Apache ActiveMQ。 axis2.xml配置为:
<parameter name="transport.jms.SessionTransacted">true</parameter>
<parameter name="transport.jms.SessionAcknowledgement" locked="true">CLIENT_ACKNOWLEDGE</parameter>
我有一个带有jms传输的简单直通代理,它将JMS队列中的消息传递给jax-rs服务。代理代码是:
<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse"
name="MediaMoveQueue"
transports="jms"
startOnLoad="true"
trace="enable">
<description/>
<target>
<inSequence>
<property name="messageType" value="application/json" scope="axis2"/>
<property name="ContentType" value="application/json" scope="axis2"/>
<send receive="JmsRollbackSequence">
<endpoint>
<address uri="http://192.168.1.2:9766/RestMediaMove_1.0.0/services/rest_media_move_i_f/restmediamoveif/hello"/>
</endpoint>
</send>
<log level="custom">
<property name="In MediaMoveQueue JMSERROR"
expression="get-property('JMSERROR')"/>
</log>
<switch source="get-property('JMSERROR')">
<case regex="true">
<property name="SET_ROLLBACK_ONLY" value="true" scope="axis2"/>
<log level="custom">
<property name="In MediaMoveQueue Transaction Action"
value="Rollbacked"/>
</log>
</case>
<case regex="false">
<log level="custom">
<property name="In MediaMoveQueue Transaction Action"
value="Committed"/>
</log>
</case>
<default>
<property name="SET_ROLLBACK_ONLY" value="true" scope="axis2"/>
<log level="custom">
<property name="In MediaMoveQueue Transaction Action default"
value="Rollbacked"/>
</log>
</default>
</switch>
</inSequence>
<outSequence>
<log level="full">
<property name="test" value="IN outsequence"/>
</log>
<send/>
</outSequence>
</target>
<parameter name="transport.jms.ContentType">
<rules>
<jmsProperty>contentType</jmsProperty>
<default>application/json</default>
</rules>
</parameter>
</proxy>
JmsRollbackSequence序列从jax-rs服务接收答复,并且根据返回的成功或失败,我想回滚JMS事务。但是如果我设置属性
在JmsRollbackSequence中,它绝对没有作用(在使用下面显示的序列之前,我先尝试了它)。交易永远不会回滚。仅当在inSequence中设置了属性时,回滚才有效。
这是JmsRollbackSequence的代码:
<?xml version="1.0" encoding="UTF-8"?>
<sequence xmlns="http://ws.apache.org/ns/synapse" name="JmsRollbackSequence">
<property name="JMSERROR" value="true"/>
<log level="full">
<property name="test" value="IN JmsRollbackSequence"/>
</log>
</sequence>
因此,我尝试在JmsRollbackSequence中设置一个名为JMSERROR的属性,并在inSequence中的发送介体之后读取该属性,以为我可以在inSequence中回滚事务。但这也不起作用。 inSequence中的switch case在JmsRollbackSequence中设置属性之前被调用,因此当我读取它时,它总是返回null。
所以我的问题是:
1)我们可以设置
<property name="SET_ROLLBACK_ONLY" value="true" scope="axis2"/>
按顺序?为什么在JmsRollbackSequence中不起作用?
2)由于应该依次调用调解器,为什么inSequence中的switch情况在JmsRollbackSequence有机会读取答复并设置JMSERROR属性之前运行?
最佳答案
我相信您只能从相同顺序或与之关联的故障顺序中控制事务。但是WSO2文档并没有对此说什么...
关于您的第二个问题:发送调解器是非阻塞的,即,以下调解器将在发送调解器返回之前执行。如果希望它等待响应,则需要使用标注调解器。然后,您可以评估响应并根据需要进行回滚(全部在inSequence内部)。