我刚刚阅读了这篇关于GAE最佳实践的伟大摘要:https://cloud.google.com/datastore/docs/best-practices
其中之一是:
如果事务失败,请确保尝试回滚事务。回滚将事务中相同资源的不同请求的重试延迟最小化。请注意,回滚本身可能失败,因此回滚应该是最好的尝试。
我认为事务回滚是GAE为您做的事情,但是上面的引语说您应该自己做。
文档这里还说您应该进行回滚,但没有说明如何回滚。
那么,如何在GAE中回滚事务呢?
发布于 2017-01-17 19:09:26
最佳实践文档是直接通过其API或客户端库使用。
这仅在灵活的Appengine环境中是必要的。即使在这种情况下,云数据存储客户端库也提供了一个自动处理回滚的上下文管理器--这个示例代码来自医生们。
def transfer_funds(client, from_key, to_key, amount):
with client.transaction():
from_account = client.get(from_key)
to_account = client.get(to_key)
from_account['balance'] -= amount
to_account['balance'] += amount
client.put_multi([from_account, to_account])文档状态:
默认情况下,如果事务块退出时出现错误,则回滚事务。
请注意,客户端库仍然在Beta中,因此这种行为在将来可能会发生变化。
在标准的Appengine环境中,ndb库提供自动事务回滚。
NDB客户端Libary可以在一个事务中对多个操作进行分组。除非事务中的每个操作都成功,否则事务无法成功;如果任何操作失败,事务将自动回滚。
https://stackoverflow.com/questions/41700447
复制相似问题