分布式事务框架dtm1.6.3发布,支持go-zero、polaris微服务框架

yedf · 2021-12-13 09:31:44 · 2830 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2021-12-13 09:31:44 的主题,其中的信息可能已经有所发展或是发生改变。

更新日志:

  • 支持go-zero
  • 支持polaris
  • 日志更新为uber/zap

跨语言分布式事务管理器

DTM是一款golang开发的分布式事务管理器,解决了跨数据库、跨服务、跨语言栈更新数据的一致性问题。

他优雅的解决了幂等、空补偿、悬挂等分布式事务难题,提供了简单易用、高性能、易水平扩展的解决方案。

作者受邀参加中国数据库大会分享多语言环境下分布式事务实践

谁在使用dtm

Tencent 腾讯

Ivydad 常青藤爸爸

Eglass 视咖镜小二

极欧科技

金数智联

亮点

  • 极易接入
    • 支持HTTP,提供非常简单的接口,极大降低上手分布式事务的难度,新手也能快速接入
  • 使用简单
    • 开发者不再担心悬挂、空补偿、幂等各类问题,框架层代为处理
  • 跨语言
    • 可适合多语言栈的公司使用。方便go、python、php、nodejs、ruby、c# 各类语言使用。
  • 易部署、易扩展
    • 仅依赖mysql,部署简单,易集群化,易水平扩展
  • 多种分布式事务协议支持
    • TCC、SAGA、XA、事务消息

与其他框架对比

目前开源的分布式事务框架,Java的框架较多,有大厂开源的SEATA、ServiceComb-Pack,shardingsphere,以及个人开源的himly,tcc-transaction,ByteTCC等等,其中以Seata的应用最为广泛。

非Java语言类的,暂未看到除dtm之外的成熟框架,因此这里仅将DTM和Java中最成熟的Seata对比: image.png

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

性能测试报告

教程与文档

各语言客户端及示例

微服务框架支持

  • go-zero:一开源就非常火爆的微服务框架,首家接入dtm的微服务框架。感谢go-zero作者kevwan的大力支持
  • polaris: 腾讯开源的注册发现组件,以及在其上构建的微服务框架。感谢腾讯同学ychensha的PR
  • 其他:看用户需求量,择机接入

欢迎使用dtm,或者通过dtm学习实践分布式事务相关知识,欢迎star支持我们


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2830 次点击  ∙  1 赞  
加入收藏 微博
6 回复  |  直到 2021-12-23 21:49:12
focusonline
focusonline · #1 · 3年之前

polaris 是站长开发的框架吗?

yedf
yedf · #2 · 3年之前

@focusonline polaris是腾讯开源的服务注册/发现组件 刚好跟站长的昵称重名了...

focusonline
focusonline · #3 · 3年之前
yedfyedf #2 回复

@focusonline polaris是腾讯开源的服务注册/发现组件 刚好跟站长的昵称重名了...

好吧 下次我要改个名叫宙斯, 让你们这些人得瑟

EddyLee1010
EddyLee1010 · #4 · 3年之前
focusonlinefocusonline #3 回复

#2楼 @yedf 好吧 下次我要改个名叫宙斯, 让你们这些人得瑟

敌法师在此,宙斯休要嚣张

ws1992go
ws1992go · #5 · 3年之前

如果这个 Mysql 挂了,那岂不是事务框架就跪了。这单点是否有点太过于明显了。

yedf
yedf · #6 · 3年之前
ws1992gows1992go #5 回复

如果这个 Mysql 挂了,那岂不是事务框架就跪了。这单点是否有点太过于明显了。

这个不是单点哈,云厂商提供的数据库是高可用的,如果你更高要求,类似金融场景,也有三节点的。

几乎每家公司都会把数据存储在数据库,大部分选择mysql,因此dtm也选择mysql,这样的选择没有问题。

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传