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();
}
我在尝试将作业放入锁定语句中时遇到错误。
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();
}