问题描述
我正在尝试使用Go通过HTTP实现 MongoDB 交易API服务
客户端将请求发送到:/db/transaction/begin
获取交易ID
为了将所有后续与交易相关的CRUD操作API请求与该交易ID绑定在一起
最后,客户端要么向/db/transaction/{transaction_id}/commit
发送请求
或/db/transaction/{transaction_id}/rollback
(有点类似于Firestore交易)
我能够使用 arangoDB 来实现这种行为,因为它是Go Driver允许我设置每个CRUD操作(https://godoc.org/github.com/arangodb/go-driver#WithTransactionID)的交易ID
但是不幸的是,我无法通过官方的MongoDB Go驱动程序实现这一目标
我错过了什么吗? 有什么解决方法或任何自定义实现可以帮助我吗?预先感谢
解决方法
更简单的解决方案是在提交端点运行时将操作存储(缓冲)到应用程序中,然后将所有操作一起提交给MongoDB。
从技术上讲,您可以在应用程序中手动管理事务生命周期并实现跨Web请求的事务,但这是1)相当尴尬和2)您将失去驱动程序在其中为您所做的各种瞬时错误处理withTransaction API。
为此:
- 熟悉sessions specification
- 熟悉transactions specification
- 阅读convenient tx api spec,以便让您知道如果您的客户问您为什么要暴露驱动程序没有提供的错误,您将免费获得
- 在驱动程序中查看实现这些规范的代码
- 为应用程序中的需求实施足够的会话和事务管理
插入和修补驱动程序可能会更容易,但这显然还有其他问题,原因是您的代码库与官方驱动程序代码库不同。