Hangfire:从关键部分排队后台工作

时间:2017-02-16 10:03:38

标签: c# multithreading critical-section hangfire offloading

我在尝试将某个作业排入锁定语句时遇到错误。

lock (lockObj)
{
    BackgroundJob.Enqueue(() => MyJob());
}

它抱怨被禁用的分布式事务。但我不希望我的锁对工作处理产生影响。如果我启用MSDTC,它会保持锁定直到作业处理完成吗?这与我的需要相反。

BackgroundJob.Enqueue()调用移到锁定块之外是不方便的,因为它可能位于另一个难以提取的方法中(实际情况要困难得多):

lock (lockObj)
{
    MainWork();
    AnotherMethod();
    MoreWork();
}

private void AnotherMethod()
{
   BackgroundJob.Enqueue(() => MyJob());
   SomeWork();
}

有人可以在这里建议我需要的重构/解决方案吗?

1 个答案:

答案 0 :(得分:2)

显示问题不是因为锁定而是因为使用了TransactionScope。所以接下来的代码就是诀窍:

private void AnotherMethod()
{
   using (var ts = new TransactionScope(TransactionScopeOption.Suppress))
   {
       BackgroundJob.Enqueue(() => MyJob());
       ts.Complete();
   }

   SomeWork();
}