乐趣区

关于后端:DTM发布184-支持零配置启动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

brew install dtm

这会装置两个命令:dtm dtm-qs,通过如下命令运行 dtm 服务器:

dtm

而后运行上面命令,即可发动一个最简略的分布式事务示例,外面是模仿的是一个跨行转账分布式事务例子

dtm-qs

能够从 dtm-qs 的日志中看到 TransOut,TransIn 的日志,表明这个事务已胜利实现

反对自定义子事务申请 header

通过设置全局事务对象中的 BranchHeaders,能够让 dtm 服务器将这些 header 传递给每个子事务,该个性能够解决子事务 API 须要权限验证的问题,应用示例如下:

    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 反对咱们。

关注【分布式事务】公众号,获取更多分布式事务相干常识,同时能够退出咱们的社群

退出移动版