在TransactionScope中调用Runspace.Open()会更改Transaction.Current并抛出异常

时间:2015-04-22 17:13:20

标签: c# powershell transactions

如果System.Management.Automation.Runspaces.Runspace.Open()恰好位于System.Transactions.TransactionScope内,则显然会更改Transaction.Current,这会在事务处理时导致'System.InvalidOperationException'。

所以这个:

using (var scope = new TransactionScope())
{
    using (var runspace = RunspaceFactory.CreateRunspace())
    {
        runspace.Open();
    }

    scope.Complete();
}

抛出:“Transaction.Teurrent在TransactionScope内发生了变化。”

我想知道我是否遗漏了Transaction或Runspace中的任何关键参数,或者它与我的power-shell / MSDTC / etc配置有什么关系?

1 个答案:

答案 0 :(得分:3)

我自己也有同样的问题。我的Runspace被埋在几个嵌套的TransactionScope层中。执行Runspace.Open()后,Transaction.Current将被更改,并根据OP的问题抛出异常。

我的解决方案是将代码包装在另一个TransactionScope内,但这次使用TransactionScopeOption.Suppress参数。

    using (var transactionScope = new TransactionScope(TransactionScopeOption.Suppress))
        {
            IEnumerable<Object> results = null;

            using (Runspace runSpace = RunspaceFactory.CreateRunspace())
            {
                runSpace.Open();

                using (Pipeline pipeline = runSpace.CreatePipeline())
                {
                    Command command = new Command(script, true, true);

                    if (parameters != null && parameters.Any())
                        foreach (var param in parameters)
                            command.Parameters.Add(param.Key, param.Value);

                    pipeline.Commands.Add(command);

                    results = pipeline.Invoke();
                }

                runSpace.Close();

                transactionScope.Complete();

                return results;
            }
        }

这对我来说很有效。没有例外。