上一篇文章“基于WS-AtomicTransaction标准的WCF远程分布式事务”写了如何配置MSDTC支持WS-AT协议和写了一段WCF代码使用WS-AT协议。但是WCF是如何支持WS-AT协议的呢?
通过用WCF本身的Log功能或者用smsniff监控一下网络消息,就可以知道MachineA和MachineB传递的消息和一般的WCF程序不一样,消息遵循了WS-AtomicTransaction工业标准。下面是监控到的一部分消息内容:
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://www.w3.org/2005/08/addressing">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<s:Header>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:Action s:mustUnderstand="1">http://tempuri.org/ICustomerService/GetCustomerName</a:Action>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:MessageID>urn:uuid:0cc037a3-7c3c-4b0e-bdf8-9856ea8b0061</a:MessageID>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:ReplyTo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:Address>http://www.w3.org/2005/08/addressing/anonymous</a:Address>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</a:ReplyTo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:To s:mustUnderstand="1">http://li/CustomerService</a:To>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Header>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<s:Body>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<GetCustomerName xmlns="http://tempuri.org/">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<customerID>1</customerID>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</GetCustomerName>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Body>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Envelope>

基于WS-AtomicTransaction标准的WCF远程分布式事务(二)<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://www.w3.org/2005/08/addressing">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<s:Header>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:Action s:mustUnderstand="1">http://tempuri.org/IOrderService/UpdateOrderStatus</a:Action>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:MessageID>urn:uuid:bf31aa58-8421-41d8-94e3-377a1235c64c</a:MessageID>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:ReplyTo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:Address>http://www.w3.org/2005/08/addressing/anonymous</a:Address>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</a:ReplyTo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<CoordinationContext s:mustUnderstand="1" xmlns="http://schemas.xmlsoap.org/ws/2004/10/wscoor" xmlns:mstx="http://schemas.microsoft.com/ws/2006/02/transactions">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<wscoor:Identifier xmlns:wscoor="http://schemas.xmlsoap.org/ws/2004/10/wscoor">urn:uuid:89ebe490-88fe-45d8-a931-bc3f88612693</wscoor:Identifier>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<Expires>58880</Expires>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<CoordinationType>http://schemas.xmlsoap.org/ws/2004/10/wsat</CoordinationType>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<RegistrationService>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<Address xmlns="http://schemas.xmlsoap.org/ws/2004/08/addressing">https://liweiguang:1443/WsatService/Registration/Coordinator/</Address>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<ReferenceParameters xmlns="http://schemas.xmlsoap.org/ws/2004/08/addressing">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<mstx:RegisterInfo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<mstx:LocalTransactionId>89ebe490-88fe-45d8-a931-bc3f88612693</mstx:LocalTransactionId>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</mstx:RegisterInfo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</ReferenceParameters>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</RegistrationService>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<mstx:IsolationLevel>0</mstx:IsolationLevel>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<mstx:LocalTransactionId>89ebe490-88fe-45d8-a931-bc3f88612693</mstx:LocalTransactionId>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<PropagationToken xmlns="http://schemas.microsoft.com/ws/2006/02/tx/oletx">AQAAAAMAAACQ5OuJ/ojYRakxvD+IYSaTAAAQAAAAAACUAAAAAP///4LS6HlX0uh5clisZ9oT8nlyWKxnYOb2A+wN+QMIXh8ApOX2A2I1YmExNmU2LTc1ODEtNDkyYi04YWE3LThkNjQwZWU1NTMwNQCp/EMKAAAAZM1kzSEAAABMSVdFSUdVQU5HAHcYAAAATABJAFcARQBJAEcAVQBBAE4ARwAAAHAuAQAAAAEAAAApAAAAdGlwOi8vbGl3ZWlndWFuZy5hc2lhcGFjaWZpYy5ocHFjb3JwLm5ldC8Agd0=</PropagationToken>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</CoordinationContext>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:To s:mustUnderstand="1">http://li/OrderService</a:To>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Header>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<s:Body>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<UpdateOrderStatus xmlns="http://tempuri.org/">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<orderID>4400000000000001</orderID>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<orderStatus>1</orderStatus>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</UpdateOrderStatus>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Body>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Envelope>

 第一段消息是没有使用事务的方法调用的消息,第二段是使用WS-AT事务的方法的调用的消息。
从第二段消息可以看出,明显加入了WS-Coordination、WS-Transaction、WS-Addressing的内容。对比一下IBM WAS生成的WS-AT消息(使用 WS-AtomicTransaction 和 JTA 的分布式事务:http://www.ibm.com/developerworks/cn/webservices/ws-wsat/ ),除了协议中自定义部分“ReferenceProperties”,其他基本上是一致的。
也可以看出来,WCF很好的实现了WS-AT协议。下一步打算测试一下WCF WS-AT和java web service的互操作性(虽然Sun声明它的产品和微软的WCF具有很好的互操作性http://www.infoq.com/cn/news/2007/04/sunmsftwsat),呵呵

如果修改一下配置文件,使用OletxTransaction,而不是WS-AT的话,就得到不一样的消息:

基于WS-AtomicTransaction标准的WCF远程分布式事务(二)<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://www.w3.org/2005/08/addressing">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<s:Header>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:Action s:mustUnderstand="1">http://tempuri.org/ICustomerService/Update</a:Action>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:MessageID>urn:uuid:08dd935a-2e77-4bd7-bad1-73fc65555d9f</a:MessageID>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:ReplyTo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:Address>http://www.w3.org/2005/08/addressing/anonymous</a:Address>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</a:ReplyTo>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<OleTxTransaction s:mustUnderstand="1" b:Expires="59904" xmlns="http://schemas.microsoft.com/ws/2006/02/tx/oletx" xmlns:b="http://schemas.xmlsoap.org/ws/2004/10/wscoor">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<PropagationToken>AQAAAAMAAADlvokJX0c9R6q9uvZOpBv+AAAQAAAAAACUAAAAAP///4LS6HlX0uh5clisZ9oT8nlyWKxn6OUJBBwOqwOgQCAALOUJBGI1YmExNmU2LTc1ODEtNDkyYi04YWE3LThkNjQwZWU1NTMwNQCp/EMKAAAAZM1kzSEAAABMSVdFSUdVQU5HAHcYAAAATABJAFcARQBJAEcAVQBBAE4ARwAAAHAuAQAAAAEAAAApAAAAdGlwOi8vbGl3ZWlndWFuZy5hc2lhcGFjaWZpYy5ocHFjb3JwLm5ldC8Agd0=</PropagationToken>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</OleTxTransaction>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<a:To s:mustUnderstand="1">http://li/CustomerService</a:To>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Header>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<s:Body>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<Update xmlns="http://tempuri.org/">
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
<customerID>1</customerID>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</Update>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Body>
基于WS-AtomicTransaction标准的WCF远程分布式事务(二)
</s:Envelope>


 

相关文章:

  • 2022-12-23
  • 2021-08-05
  • 2021-10-22
  • 2021-04-01
  • 2021-11-16
猜你喜欢
  • 2021-12-06
  • 2021-05-17
  • 2021-12-17
  • 2022-12-23
  • 2021-09-11
  • 2022-12-23
  • 2021-07-15
相关资源
相似解决方案