🔥A cross-language distributed transaction manager. Support xa, tcc, saga, transactional messages. 跨语言分布式事务管理器
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

39 lines
758 B

package examples
import (
"time"
"github.com/sirupsen/logrus"
"github.com/yedf/dtm/common"
"github.com/yedf/dtm/dtm"
)
func Main() {
go StartSvr()
FireRequest()
time.Sleep(1000 * time.Second)
}
func FireRequest() {
gid := common.GenGid()
logrus.Printf("busi transaction begin: %s", gid)
req := &TransReq{
Amount: 30,
TransInFailed: false,
TransOutFailed: false,
}
saga := dtm.SagaNew(DtmServer, gid, Busi+"/TransQuery")
saga.Add(Busi+"/TransIn", Busi+"/TransInCompensate", req)
saga.Add(Busi+"/TransOut", Busi+"/TransOutCompensate", req)
saga.Prepare()
logrus.Printf("busi trans commit")
saga.Commit()
}
func StartSvr() {
logrus.Printf("examples starting")
app := common.GetGinApp()
AddRoute(app)
app.Run(":8081")
}