0

我正在使用天蓝色表查询来检索分配给用户的所有错误实体。之后我更改实体的属性以声明实体处于处理模式。处理完实体后,我从表中删除了实体。

当我进行并行测试时,可能会发生在查询期间,一个实体已经被另一个线程处理和删除。因此,当我想替换实体时,我收到错误 404 ResourceNotFound。

有没有办法测试实体是否在线程之外更改或者它是否仍然存在?捕获错误 404 并忽略它会更好,还是我应该再次查询实体(对我来说似乎都不合适)?

TableQuery<ErrorObjectTableEntity> query = new TableQuery<ErrorObjectTableEntity>().Where(TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, user));
List<ErrorObjectTableEntity> queryResult = table.ExecuteQuery(query).OrderBy(x => x.action).ToList();
foreach (ErrorObjectTableEntity entity in queryResult)
{
     entity.inProcess = true;
     try
     {
         TableOperation updateOperation = TableOperation.Replace(entity);
         table.Execute(updateOperation);     
      }
      catch
      {
          //..some logging here
          //catch error 404?
      }
      //do some action
      try
      {
          TableOperation deleteOperation = TableOperation.Delete(entity);
          table.Execute(deleteOperation);
      }
      catch{...}
}
4

2 回答 2

0

您应该只捕获 404 错误。尽管它们在 .NET 中表示为异常,但 HTTP 4xx 错误代码比异常提供的信息更多。(5xx 错误代码是例外的。)

即使您在进行替换之前检查了实体是否存在,您仍然需要捕获 NotFound 错误,以防它在检查和替换调用之间被删除。所以你不妨跳过检查。

于 2013-09-13T12:37:22.287 回答
0

就最佳实践而言,这里有几个问题。假设另一个工作人员将其删除,您编写的代码可以简单地忽略异常,但这最终可能会掩盖其他类别的错误。一种解决方案是使用队列为每个用户查询插入消息,然后让各种工作人员检索消息并处理特定用户的查询。这样,如果一个节点出现故障,应用程序将吸收故障并继续运行。此外,这将防止您的工作人员重复工作,从而优化整个应用程序。最后,如果您不关心实体的状态并且键是可预测的,您可以使用 Merge 语义来简单地更新实体的给定属性,而无需替换整个事物。

于 2013-09-16T21:56:27.160 回答