dtm/README.md
2021-09-14 20:15:57 +08:00

5.6 KiB
Raw Blame History

license Build Status Coverage Status Go Report Card Go Reference Mentioned in Awesome Go

English Docs

GO语言分布式事务管理服务

谁在使用dtm

Ivydad 常青藤爸爸

Eglass 视咖镜小二

极欧科技

金数智联

可以做什么

  • 一站式解决分布式事务需求
    • 支持TCC、SAGA、XA、事务消息、可靠消息
  • 支持跨语言栈事务
    • 支持多语言栈混合的分布式事务。支持Go、Python、PHP、Nodejs、Java、c# 各类语言SDK。
  • 自动处理子事务乱序
    • 首创子事务屏障技术,框架层自动处理悬挂、空补偿、幂等网络异常问题
  • 支持单服务多数据源访问
    • 通过子事务屏障技术,保证单服务多数据源访问的一致性,也能保证本地长事务拆分多个子事务后的一致性
  • 开箱即用,提供云上服务
    • 支持通用的HTTP、gRPC协议接入云原生友好。支持Mysql接入。提供测试版本的云上服务方便新用户测试接入

与其他框架对比

目前开源的分布式事务框架暂未看到非Java语言有成熟的框架。而Java语言的较多其中以seata应用最为广泛。

下面是DTM和SEATA的主要特性对比

特性 DTM SEATA 备注
支持语言 Go、Java、python、php、c#... Java dtm可轻松接入一门新语言
异常处理 子事务屏障自动处理 手动处理 dtm解决了幂等、悬挂、空补偿
TCC事务
XA事务
AT事务 AT与XA类似性能更好但有脏回滚
SAGA事务 简单模式 状态机复杂模式 dtm的状态机模式在规划中
事务消息 dtm提供类似rocketmq的事务消息
通信协议 HTTP、gRPC dubbo等协议无HTTP
star数量 github stars github stars dtm从20210604发布0.1,发展快

从上面对比的特性来看如果您的语言栈包含了Java之外的语言那么dtm是您的首选。如果您的语言栈是Java您也可以选择接入dtm使用子事务屏障技术简化您的业务编写。

教程与文档

各语言客户端及示例

快速开始

安装

git clone https://github.com/yedf/dtm

dtm依赖于mysql

配置mysql

cp conf.sample.yml conf.yml # 修改conf.yml

启动并运行saga示例

go run app/main.go saga

开始使用

使用

  // 具体业务微服务地址
  const qsBusi = "http://localhost:8081/api/busi_saga"
  req := &gin.H{"amount": 30} // 微服务的载荷
  // DtmServer为DTM服务的地址是一个url
  DtmServer := "http://localhost:8080/api/dtmsvr"
  saga := dtmcli.NewSaga(DtmServer, dtmcli.MustGenGid(DtmServer)).
    // 添加一个TransOut的子事务正向操作为url: qsBusi+"/TransOut" 补偿操作为url: qsBusi+"/TransOutCompensate"
    Add(qsBusi+"/TransOut", qsBusi+"/TransOutCompensate", req).
    // 添加一个TransIn的子事务正向操作为url: qsBusi+"/TransIn" 补偿操作为url: qsBusi+"/TransInCompensate"
    Add(qsBusi+"/TransIn", qsBusi+"/TransInCompensate", req)
  // 提交saga事务dtm会完成所有的子事务/回滚所有的子事务
  err := saga.Submit()

成功运行后可以看到TransOut、TransIn依次被调用完成了整个分布式事务

时序图

上述saga分布式事务的时序图如下

完整示例

参考examples/quick_start.go

交流群

请加 yedf2008 好友或者扫码加好友,验证回复 dtm 按照指引进群

yedf2008

如果您觉得dtm不错,或者对您有帮助,请赏颗星吧!

谁在使用

常青藤爸爸 镜小二 极欧科技 金数智联