首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >调用Runspace.Open()在TransactionScope中更改Transaction.Current并引发异常

调用Runspace.Open()在TransactionScope中更改Transaction.Current并引发异常
EN

Stack Overflow用户
提问于 2015-04-22 17:13:20
回答 1查看 405关注 0票数 3

如果System.Management.Automation.Runspaces.Runspace.Open()碰巧在一个System.Transactions.TransactionScope中,那么显然它会改变Transaction.Current,这反过来会在事务处理时导致'System.InvalidOperationException‘。

所以这个:

代码语言:javascript
复制
using (var scope = new TransactionScope())
{
    using (var runspace = RunspaceFactory.CreateRunspace())
    {
        runspace.Open();
    }

    scope.Complete();
}

抛出:"Transaction.Current在TransactionScope中发生了变化。“

我想知道我是否遗漏了事务或运行空间中的任何关键参数,还是与我的power-shell/MSDTC/etc配置有关?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-20 20:48:30

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

对于我来说,解决方案是将代码包装到另一个TransactionScope中,但这次是使用TransactionScopeOption.Suppress参数。

代码语言:javascript
复制
    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;
            }
        }

这对我来说是完美的。不再有例外。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29804554

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档