我已将 EventGrid 订阅配置为在创建资源时为资源组中的事件启动 Web 挂钩调用。
成功处理了网络挂钩调用,我返回 200 OK。为了保持幂等性,我将所有发生的事件webhook_events
与事件的 一起存储在一个表中id
。任何新事件都会被检查以查看它们是否存在于该表中id
。
Azure EventGrid 在返回 200 OK 后尝试从重试队列中删除事件。无论我以 200 OK 响应的速度有多快,EventGrid 都会可靠地重试发送。
我多次收到相同的事件(正如我所说,EventGrid 总是重试,因为它不能足够快地从重试队列中删除事件)。然而,这不是我问题的重点;相反,问题在于这些重试中的每一次都为我提供了不同id
的事件。这意味着我无法从逻辑上确定事件的唯一性,并且我的应用程序代码没有以幂等方式执行。
尽管事件重试之间没有唯一标识符,我如何在我的应用程序和 Azure 之间保持幂等性?