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

66 lines
1.6 KiB

package main
import (
"fmt"
"os"
"strings"
"time"
"github.com/yedf/dtm/dtmcli"
"github.com/yedf/dtm/dtmsvr"
"github.com/yedf/dtm/examples"
)
// M alias
type M = map[string]interface{}
func wait() {
for {
time.Sleep(10000 * time.Second)
}
}
func main() {
if len(os.Args) == 1 {
for _, ln := range []string{
"dtm is a lightweight distributed transaction manager.",
"usage:",
"dtm [command]",
"",
"Available Commands:",
"dtmsvr run dtm as a server.",
"dev create all needed table and run dtm as a server.",
"",
"quick_start run quick start example. dtm will create all needed table",
"qs same as quick_start",
} {
fmt.Print(ln + "\n")
}
for name := range examples.Samples {
fmt.Printf("%-18srun a sample includes %s\n", name, strings.Replace(name, "_", " ", 100))
}
return
}
if os.Args[1] != "dtmsvr" { // 实际线上运行,只启动dtmsvr,不准备table相关的数据
dtmsvr.PopulateDB(true)
examples.PopulateDB(true)
}
dtmsvr.StartSvr() // 启动dtmsvr的api服务
go dtmsvr.CronExpiredTrans(-1) // 启动dtmsvr的定时过期查询
// quick_start 比较独立,单独作为一个例子运行,方便新人上手
if os.Args[1] == "quick_start" || os.Args[1] == "qs" {
examples.QsStartSvr()
examples.QsFireRequest()
} else if os.Args[1] == "dev" || os.Args[1] == "dtmsvr" {
} else {
// 下面是各类的例子
examples.GrpcStartup()
examples.BaseAppStartup()
sample := examples.Samples[os.Args[1]]
dtmcli.LogIfFatalf(sample == nil, "no sample name for %s", os.Args[1])
sample.Action()
}
wait()
}