🔥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.
 
 
 
 
 
 

40 lines
903 B

package main
import (
"os"
"time"
"github.com/sirupsen/logrus"
"github.com/yedf/dtm/dtmsvr"
"github.com/yedf/dtm/examples"
)
type M = map[string]interface{}
func main() {
if len(os.Args) == 1 { // 默认情况下,展示saga例子
dtmsvr.PopulateMysql()
go dtmsvr.StartSvr()
go examples.SagaStartSvr()
time.Sleep(100 * time.Millisecond)
examples.SagaFireRequest()
} else if os.Args[1] == "dtmsvr" { // 只启动dtmsvr
go dtmsvr.StartSvr()
} else if os.Args[1] == "all" { // 运行所有示例
dtmsvr.PopulateMysql()
examples.PopulateMysql()
go dtmsvr.StartSvr()
go examples.SagaStartSvr()
go examples.TccStartSvr()
go examples.XaStartSvr()
time.Sleep(100 * time.Millisecond)
examples.SagaFireRequest()
examples.TccFireRequest()
examples.XaFireRequest()
} else {
logrus.Fatalf("unknown arg: %s", os.Args[1])
}
for {
time.Sleep(1000 * time.Second)
}
}