2

我有一个使用 Com+ 的 .Net 2.0 Windows 服务,可以将 xml 数据导入数据库,而且大多数时候它工作得很好。

但是,有时(很少)我会抛出事务代理异常。(过去两个月发生过一次,在此期间有 250 000 次处决是正确的)。

最糟糕的是,数据被正确地导入数据库,但是抛出异常并且事务没有回滚。我尝试手动创建异常并验证事务处理是否正确。

你以前见过这个吗?网上关于这个错误的信息不多。该服务在带有 SP2 的 Server 2003 上运行。

抛出的异常是:

System.EnterpriseServices.TransactionProxyException

System.EnterpriseServices.TransactionProxyException 和堆栈跟踪:

System.EnterpriseServices.TransactionProxy.MapTxExceptionToHR(TransactionExceptiontxException, Boolean isInCommit)
at System.EnterpriseServices.TransactionProxy.Commit(Guid guid)
at System.Runtime.InteropServices.Marshal.ThrowExceptionForHRInternal(Int32 errorCode, IntPtr errorInfo) at System.EnterpriseServices.Thunk.Callback.DoCallback(Object otp, IMessage msg, IntPtr ctx, Boolean fIsAutoDone, MemberInfo mb, Boolean bHasGit) at System.EnterpriseServices.ServicedComponentProxy.CrossCtxInvoke(IMessage reqMsg) at System.EnterpriseServices.ServicedComponentProxy.Invoke(IMessage request)
at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
at MyService

4

1 回答 1

0

也许尝试更改这些 DTC 设置?

http://support.microsoft.com/kb/2556390

于 2012-10-31T07:10:23.397 回答