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

Hangfire: enqueue background job from inside a critical section

我在尝试将作业放入锁定语句中时遇到错误。

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

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

BackgroundJob.Enqueue() 调用移动到锁块之外并不方便,因为它可能在另一个方法中,这使得提取变得困难(实际情况要困难得多):

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

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

谁能推荐一下refactoring/solution我需要这里吗?

表明问题不是因为锁定,而是因为使用了 TransactionScope。所以下一个代码成功了:

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

   SomeWork();
}