gpt4 book ai didi

azure - 带有文档的 Azure CosmosDB 如何避免同时编辑单个文档?

转载 作者:行者123 更新时间:2023-12-02 03:38:34 25 4
gpt4 key购买 nike

我有一个 Azure Cosmos DB,其中包含一个 UserData 集合,其中包含多个用户文档。

通过 azure 函数编辑文档,该函数获取文档,将 json 解析为类,根据需要编辑类,然后将其设置回用户文档。

那么,如果在执行该操作时调用另一个 azure 函数,从 Azure Cosmos DB 抓取文档并在第一个函数完成之前进行其他更改,会怎么样?即使它更改了文档中完全独立的字段,其他字段仍然保持不变,并且 Azure 没有明显的方法来知道要覆盖哪些字段以及要保留哪些字段。

处理此问题的唯一方法是,对文档的请求要等到首先请求它的函数完成请求后,但我又不知道 Azure 如何解决这个问题。

最佳答案

默认情况下,Cosmos DB 不会阻止此行为,但您可以通过使用 etag 实现乐观并发来控制这种行为。

本质上,您要做的就是每当发送文档更新请求时,都将文档的 etag 与请求一起发送。如果 etag 与服务器上文档的 etag 值匹配,则更新请求将成功,否则将失败(应该带有 419 状态代码,但文档没有提到这一点)。如果失败,您可以获取最新的文档(及其 etag),更新它并再次发送更新的文档。

来自Replace a Document REST API 文档(请参阅请求 header 部分):

If-Match

String Used to make operation conditional for optimistic concurrency. i.e. the document is updated only if the specified etag matches the current version in the database. The value should be set to the etag value of the resource.

关于azure - 带有文档的 Azure CosmosDB 如何避免同时编辑单个文档?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49376834/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com