我有一个运行在MSMQ上的WCF日志记录服务。项目将记录到Sql Server2005数据库中。如果在TransactionScope之外使用,每个函数都能正常工作。当在TransactionScope实例中使用时,该调用总是导致事务中止。Message =“事务已中止”。
我需要做什么才能让这个调用在事务中工作?有没有可能。我读到,要让客户端事务跨越服务边界,绑定必须支持事务流,这会立即将绑定限制为只有NetNamedPipeBinding、NetTcpBinding、WSHttpBinding、WSDualHttpBinding和WSFederationHttpBinding。
发布于 2009-10-06 08:21:41
我对MSMQ知之甚少,但在MSMQ, IIS and WCF: Getting them to play nicely上有一篇由Tom Hollander撰写的非常好的博客文章系列-在第3部分中,这是Tom谈论的事务性的链接。
MSMQ可以是事务性的,也可以不是事务性的。在WCF中,您可以使用与事务相关的属性来修饰服务契约和单个操作契约(方法),例如是否允许、不允许或要求事务上下文。
据我所知,在您的设置中,您不希望MSMQ部分是事务性的-但即使存在环境事务,您也应该能够使用它。在这种情况下,您需要在您的操作契约中添加TransactionFlow="ALlowed“,如下所示:
[ServiceContract]
public interface ILoggingService
{
[OperationContract]
[TransactionFlow(TransactionFlowOption.Allowed)]
void LogData(......);
}这应该就行了!
Marc
发布于 2009-10-06 08:15:47
很抱歉问了这么多不必要的问题...
我已经解决了我的问题。我需要把它放在
[TransactionFlow(TransactionFlowOption.Allowed)]关于服务合同中的操作,然后
[OperationBehavior(TransactionScopeRequired=true)] 关于契约(服务本身)的实现。
这是一种享受。
https://stackoverflow.com/questions/1524079
复制相似问题