我在尝试将作业放入 lock 语句中时出错。
lock (lockObj)
{
BackgroundJob.Enqueue(() => MyJob());
}
它提示分布式事务被禁用。但我不希望我的锁影响工作处理。如果我启用 MSDTC,它会保持锁定直到作业处理完成吗?这与我需要的相反。
将
BackgroundJob.Enqueue()
调用移到锁块之外并不方便,因为它可能位于另一个方法中,这使得它难以提取(实际情况要困难得多):lock (lockObj)
{
MainWork();
AnotherMethod();
MoreWork();
}
private void AnotherMethod()
{
BackgroundJob.Enqueue(() => MyJob());
SomeWork();
}
有人可以在这里建议我需要的重构/解决方案吗?
最佳答案
发现问题不是因为锁而是因为使用了 TransactionScope。所以下一个代码成功了:
private void AnotherMethod()
{
using (var ts = new TransactionScope(TransactionScopeOption.Suppress))
{
BackgroundJob.Enqueue(() => MyJob());
ts.Complete();
}
SomeWork();
}
关于c# - Hangfire:从关键部分内排队后台作业,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42270655/