分布式事务实战--go语言的saga事务

本文介绍了在使用Go语言进行微服务开发时遇到的分布式事务挑战,团队内部开发了DTM项目来解决这一问题。DTM是一个支持HTTP和跨语言的分布式事务中间件,尤其适合Go语言环境。文中通过一个简单的saga事务示例,展示了如何在Go中接入DTM,确保分布式事务的原子性和一致性。详细信息可参考开源项目yedf/dtm。
摘要由CSDN通过智能技术生成

我们团队在引入go语言做微服务的过程中,遇见了分布式事务的强需求。我们的交易中心涉及大量的业务,包括了商品、库存、各类营销活动、商品权限等等,按照我们微服务的设计,需要拆分到多个微服务。原先由本地事务保证的ACID,现在需要分布式事务方案来保证交易的正确性。

我们调研了大量开源项目,发现只有java提供了分布式事务的中间件,其他语言,暂未发现成熟的方案。这种背景下,我们内部开发了针对go语言分布式事务的DTM项目,线上稳定之后,我们将它开源出来,github地址为:yedf/dtm 。

虽然DTM最初针对我们的go语言微服务,但是我们的设计方案,充分考虑了跨语言特性,将底层通信设计成HTTP(未来会支持grpc),并且将客户端做的非常轻,代码量非常少。

下面我们来看一个Go语言接入DTM的简单例子:

const DtmServer = "http://localhost:8080/api/dtmsvr"
const startBusi = "http://localhost:8081/api/busi_saga"
req := &gin.H{"amount": 30} // 微服务的负荷
// 生成dtm的saga对象
saga := dtm.SagaNew(DtmServer).
  // 添加两个子事务
  Add(startBusi+"/TransOut", startBusi+"/TransOutCompensate", req).
  Add(startBusi&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值