登录
首页 >  数据库 >  MySQL

DTM发布1.8.4 支持零配置启动,brew一键安装

来源:SegmentFault

时间:2023-01-10 10:06:56 338浏览 收藏

数据库小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《DTM发布1.8.4 支持零配置启动,brew一键安装》带大家来了解一下DTM发布1.8.4 支持零配置启动,brew一键安装,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!

DTM发布了最新版本1.8.4,主要更新如下:

  1. 零配置启动,对新人上手更加友好,不依赖docker、不依赖数据库,零依赖,零配置直接启动
  2. 支持homebrew一键安装
  3. 支持自定义子事务请求header
  4. 支持HTTP/gRPC拦截器
  5. 支持自定义服务端和SDK中使用的数据库表名

零配置启动

最新版本1.8.4,可以在这个页面下载相应平台(支持linux,Mac,windows)的安装包

https://github.com/dtm-labs/dtm/releases/tag/v1.8.4

解压后直接运行即可启动。默认情况下,dtm使用内嵌的boltdb存储引擎(etcd也使用该存储引擎),他会在当前目录下创建dtm.bolt文件,该文件保存了全局事务进度。

新方式下,用户不再需要docker、不需要事先安装数据库,大大降低新人的上手难度,能够快速开启分布式事务体验之旅。

boltdb存储引擎下,清理过期数据功能,由社区的杨松林,https://github.com/lsytj0413 贡献,特别感谢

homebrew 一键安装

为了最大程度的方便开发人员使用dtm,我们还将dtm发布到了homebrew,您如果在mac上工作,只需要如下一行简单命令,即可安装dtm

    gidYes := dtmimp.GetFuncName()
    sagaYes := dtmcli.NewSaga(dtmutil.DefaultHttpServer, gidYes)
    sagaYes.BranchHeaders = map[string]string{
        "test_header": "test",
    }
    sagaYes.WaitResult = true
    sagaYes.Add(busi.Busi+"/TransOutHeaderYes", "", nil)
    err := sagaYes.Submit()

在dtm-labs/dtm-examples下,还有更多的例子,包括HTTP和gRPC协议的例子

支持HTTP/gRPC拦截器

dtm的SDK添加了HTTP/gRPC拦截器的支持,如果你需要对相关请求深入的定制,可以通过以下三个拦截器接口,进行定制

func OnBeforeRequest(middleware func(c *resty.Client, r *resty.Request) error)

func OnAfterResponse(middleware func(c *resty.Client, resp *resty.Response) error)

func AddUnaryInterceptor(interceptor grpc.UnaryClientInterceptor)

支持自定义服务端和SDK中使用的数据库表名

SDK中添加如下函数,允许自定义子事务屏障的表名:

SetBarrierTableName

服务器端支持自定义全局事务表和分支事务操作表的表名,配置名称为:

Store.TransGlobalTable
Store.TransBranchOpTable

项目地址

关于分布式事务更多的理论知识与实践,可以访问以下项目和公众号:

https://github.com/dtm-labs/dtm ,欢迎访问,并star支持我们。

关注【分布式事务】公众号,获取更多分布式事务相关知识,同时可以加入我们的社群

理论要掌握,实操不能落!以上关于《DTM发布1.8.4 支持零配置启动,brew一键安装》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>