3

我使用 azure table storage 阅读了有关同一分区内的实体组事务的信息。现在,如果我将 Azure 队列与表存储一起使用会发生什么。是否可以从队列中处理消息,插入表存储。如果出现问题,回滚并再次将消息放入队列?

或者我应该如何使用 Azure 处理这种情况

4

1 回答 1

6

表和队列没有任何关联的事务。

以下是一些通用队列使用指南:

  • 确保队列操作是幂等的- 也就是说,您将多次执行队列消息得到相同的结果,并具有可重复的副作用
  • 设置一个合理的队列消息可见性超时。如果您的任务看起来需要更长的时间,您可以延长消息的不可见超时。这可以防止其他线程/角色实例在您仍在处理相同的队列项时获取它。
  • 对于长时间运行的任务(或者您希望尽可能避免多次消耗资源的任务),沿途修改您的队列消息,为自己提供状态提示。例如:您有一个渲染视频队列消息:'RENDER|Source-URL'. 您正在渲染视频,它需要两次通过。您已经完成了第 1 步,结果存储在一个临时 blob 中。您可以使用类似'RENDER|Source-URL|Pass1-URL'. 现在,假设出现问题并且您的渲染任务由于某种原因失败。稍后,当您再次收到此消息时,您可以从第 2 步开始,而不是从头开始。
  • 您无需担心将消息放回队列中。在您明确删除消息之前,它们实际上不会从队列中删除。它们只是在您选择的隐身超时期间变得隐身。如果您在该期限结束前未删除(或延长期限),则该消息将再次可见,供其他人阅读。注意:此时,一旦其他人读取队列消息,原来的消息持有者将无法再删除该消息。
于 2012-02-07T10:31:21.510 回答