我们有一个worker角色,它根据查询结果处理记录并根据需要发送Azure服务总线消息,这基本上是一个队列处理服务。作为使用SQL Azure的最佳实践的一部分,我们使用重试策略包装了所有查询语句(这会检测瞬态错误,并将根据定义的策略重试)。请注意,我们实际上是从using语句中发送消息,因此db变量没有“泄漏”。
在我们的using语句中,ReSharper正在抛出'Access to Disposed Closure'警告,很可能是因为我们将DataContext作为重试策略的func参数传递。
我的问题是,我是否可以认为ReSharper没有正确检测到这种模式,或者我们如何编写这些函数以防止上述警告?
守则
retryPolicy.ExecuteAction中的db变量是被标记的内容
using (var db = new MyEntities())
{
var thingsToUpdate = retryPolicy.ExecuteAction(() => db.QueueTable.Where(x => x.UpdateType == "UpdateType" && x.DueNext < DateTime.UtcNow).Take(30).ToList());
if (!thingsToUpdate.Any())
{
return;
}
while (thingsToUpdate.Any())
{
var message = new ServiceMessage{
Type = "UpdateType",
Requests = thingsToUpdate.Select(x => new ServiceMessageRequest
{
LastRan = x.LastRan,
ParentItemId = x.ThingId,
OwnerId = x.Thing.ForiegnKeyid
}).ToList()
};
SendMessage("UpdateType", message);
foreach (var thing in thingsToUpdate )
{
thing.LastRan = DateTime.UtcNow;
thing.DueNext = DateTime.UtcNow.AddMinutes(10);
}
retryPolicy.ExecuteAction(() => db.SaveChanges());
thingsToUpdate = db.QueueTable.Where(x => x.UpdateType == "UpdateType" && x.DueNext < DateTime.UtcNow).Take(30).ToList());
}
}
其他信息
我还将此发布到ReSharper论坛,面向更广泛的受众群体,并在此处详细介绍了这一特定问题。对于后代,您可以找到question here.