C# Hangfire:将后台作业从关键区域内排队
尝试将作业排入lock语句中时出错C# Hangfire:将后台作业从关键区域内排队,c#,multithreading,critical-section,hangfire,offloading,C#,Multithreading,Critical Section,Hangfire,Offloading,尝试将作业排入lock语句中时出错 lock (lockObj) { BackgroundJob.Enqueue(() => MyJob()); } 它抱怨分布式事务被禁用。但我不想我的锁影响工作处理。如果我启用MSDTC,它会保持锁定直到作业处理完成吗?这与我需要的正好相反 将BackgroundJob.Enqueue()调用移到锁块之外是不方便的,因为它可能位于另一个方法中,这使得提取比较困难(实际情况要困难得多): 有谁能提出我需要的重构/解决方案吗?透露问题不是因为锁,而
lock (lockObj)
{
BackgroundJob.Enqueue(() => MyJob());
}
它抱怨分布式事务被禁用。但我不想我的锁影响工作处理。如果我启用MSDTC,它会保持锁定直到作业处理完成吗?这与我需要的正好相反
将BackgroundJob.Enqueue()
调用移到锁块之外是不方便的,因为它可能位于另一个方法中,这使得提取比较困难(实际情况要困难得多):
有谁能提出我需要的重构/解决方案吗?透露问题不是因为锁,而是因为使用了TransactionScope。因此,下一个代码实现了这个技巧:
private void AnotherMethod()
{
using (var ts = new TransactionScope(TransactionScopeOption.Suppress))
{
BackgroundJob.Enqueue(() => MyJob());
ts.Complete();
}
SomeWork();
}
不,锁将在排队后释放,而不是在完成作业后释放
private void AnotherMethod()
{
using (var ts = new TransactionScope(TransactionScopeOption.Suppress))
{
BackgroundJob.Enqueue(() => MyJob());
ts.Complete();
}
SomeWork();
}