我有一个我这样配置的事务管理器
<txnmgr name="txnmgr" logger="Q2" class="org.jpos.transaction.TransactionManager">
<property name="space" value="tspace:mySpace"/>
<property name="queue" value="TransactionQueue"/>
<property name="max-sessions" value="10"/>
<participant class="main.java.com.transaction.manager.Switch" logger="Q2">
<property name="0800" value="NetworkManagement" />
<property name="0200" value="FinancialTransaction" />
</participant>
<participant class="main.java.com.transaction.manager.FinancialTransactionResponse" logger="Q2"/>
<group name="NetworkManagement">
<participant class="main.java.com.transaction.manager.NetworkManagementResponse" logger="Q2" />
</group>
<group name="FinancialTransaction">
<participant class="main.java.com.transaction.manager.FinancialTransactionValidateMessage" logger="Q2" />
<participant class="main.java.com.transaction.manager.FinancialTransactionQueryRemoteHost1" logger="Q2" />
<participant class="main.java.com.transaction.manager.FinancialTransactionQueryRemoteHost2" logger="Q2" />
</group>
</txnmgr>
在我的FinancialTransactionQueryRemoteHost1中
@Override
public int prepare(long l, Serializable srlzbl) {
try{
channelManager = ((ChannelManager) NameRegistrar.get("jpos-host1-adaptor"));
ISOMsg reqMsg = (ISOMsg) ((Context) srlzbl).get(Constants.REQUEST_KEY);
ISOMsg respMsg = channelManager.sendMsg(reqMsg);
((Context) srlzbl).put(Constants.RESPONSE_KEY, respMsg);
return PREPARED;
}catch(NameRegistrar.NotFoundException e){
e.printStackTrace();
return ABORTED;
}catch(Throwable t){
t.printStackTrace();
return ABORTED;
}
}
在我的FinancialTransactionQueryRemoteHost2中有
@Override
public int prepare(long l, Serializable srlzbl) {
try{
channelManager = ((ChannelManager) NameRegistrar.get("jpos-host2-adaptor"));
ISOMsg reqMsg = (ISOMsg) ((Context) srlzbl).get(Constants.REQUEST_KEY);
ISOMsg respMsg = channelManager.sendMsg(reqMsg);
((Context) srlzbl).put(Constants.RESPONSE_KEY, respMsg);
return PREPARED;
}catch(NameRegistrar.NotFoundException e){
e.printStackTrace();
return ABORTED;
}catch(Throwable t){
t.printStackTrace();
return ABORTED;
}
}
在我的Financialtransactionresponse中我有
@Override
public int prepare(long id, Serializable context) {
Context ctx = (Context)context;
ISOMsg respMsg = (ISOMsg)ctx.get(Constants.RESPONSE_KEY);
//Get IsoMsg from host1
//Get IsoMsg from host2
//compare field 39 response if both are 00
String bit39 = respMsg.getString(70);
if(bit39==null){
respMsg.set(39,"06");
}
ctx.put(Constants.RESPONSE_KEY,respMsg);
return PREPARED;
}
在我的交易回复中如何获得2位参与者的回复,以便我可以在回复之前进行比较,即上述关于我希望如何实现的评论
答案 0 :(得分:2)
您只需将响应放在两个不同的键下。让我们说一下response1和response2:
在FinancialTransactionQueryRemoteHost1.prepare
:
((Context) srlzbl).put("response1", respMsg);
在FinancialTransactionQueryRemoteHost2.prepare
:
((Context) srlzbl).put(Constants.RESPONSE_KEY, respMsg);
然后在Financialtransactionresponse.prepare
ISOMsg resp1 = ctx.get("response1"), resp2 = ctx.get("response2");
您可以使用您想要的任何字符串并为它们定义容器。您可以将de CONTEXT_KEY
用作第一个,另一个键用于第二个。
此外,也许更好的是,您可以合并FinancialTransactionQueryRemoteHost2
参与者的回复。
FYI参与者按顺序进行。
您可以重复使用标准的QueryHost参与者,请参阅this tutorial
感谢Murtuza Chhil response到ISOMsg parallel request to multiple MUX jpos线程,您还可以使用Parallel Processing中所述的加入参与者来同时进行两个查询。