公司要使用wcf开发接口部分,好多东西他们都已经封装好了,我只是再他们封装完毕的基础上增加了一些基本的增删改的方法
当再客户端使用事务(TransactionScope)时发现,一直提示
该伙伴事务管理器已经禁止了它对远程/网络事务的支持。 (异常来自 HRESULT:0x8004D025)
同样的数据,同样的方法,不适用事务管理器就没有问题
网上搜了一下说要开通MSDTC服务,但是服务器和客户端都在本地,localhost 只有数据库不是本地的
步骤
1.我先开通了本地的msdtc服务,设置项如下
接着再试,还是不行,还是提示那个错误
2.由于数据库是其他机器上的,把涉及相关表结构导到本地测试数据库中
服务器端的地址修改为本机测试数据库
启客户端、服务器端接着测试,发现ok
美中不足的,服务器现在每个方法里面当遇到异常的时候都直接处理了,当事务里面调用多个方法,且其中一个方法时出错时就不会回滚事务。可要是把每个方法的异常都抛出来的话,本地测试的是控制台应用程序,就会提示 控制台应用程序结束;由于每个方法的[TransactionFlow(TransactionFlowOption.Allowed)]都是这个设置项,当客户端不使用事务的话,直接返给客户一个异常貌似不太合适(写2个方法的自动忽略,后期维护太大)
附TransactionFlowOption成员含义
NotAllowed | 事务不应成为流。 这是默认值。 | |
Allowed | 事务可以成为流。 | |
Mandatory | 事务必须成为流。 |
寻求新的解决方案