SJA APS后端代码
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.

143 lines
3.3 KiB

3 years ago
3 years ago
3 years ago
3 years ago
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "github.com/kardianos/service"
  6. "leit.com/leit_seat_aps/common"
  7. "leit.com/leit_seat_aps/config"
  8. "leit.com/leit_seat_aps/db"
  9. "leit.com/leit_seat_aps/etcd"
  10. "leit.com/leit_seat_aps/glog"
  11. "leit.com/leit_seat_aps/seq"
  12. "log"
  13. "os"
  14. "path/filepath"
  15. )
  16. //基于windows系统服务器,安装成服务
  17. type program struct{}
  18. func (p *program) Start(s service.Service) error {
  19. // Start should not block. Do the actual work async.
  20. go p.run()
  21. return nil
  22. }
  23. func (p *program) run() {
  24. imain()
  25. }
  26. func (p *program) Stop(s service.Service) error {
  27. return nil
  28. }
  29. func main() {
  30. svcConfig := &service.Config{
  31. Name: "seq",
  32. DisplayName: "seq",
  33. Description: "this is seq",
  34. }
  35. prg := &program{}
  36. s, err := service.New(prg, svcConfig)
  37. if err != nil {
  38. log.Fatal(err)
  39. }
  40. if len(os.Args) > 1 {
  41. verb := os.Args[1]
  42. switch verb {
  43. case "install":
  44. s.Install()
  45. log.Println("服务安装成功")
  46. return
  47. case "remove":
  48. s.Uninstall()
  49. log.Println("服务卸载成功")
  50. return
  51. case "start":
  52. s.Start()
  53. log.Println("服务启动")
  54. return
  55. case "stop":
  56. s.Stop()
  57. log.Println("服务暂停")
  58. return
  59. }
  60. }
  61. err = s.Run()
  62. if err != nil {
  63. log.Println(err)
  64. }
  65. }
  66. /**系统入口函数,按项目依次启动TOD、SEQ、REORDER、CALLOFF的解析服务**/
  67. func imain(){
  68. //初始化日志
  69. baseDir := ""
  70. flag.StringVar(&baseDir, "dir", "log", "running in a directory")
  71. flag.Parse()
  72. defer glog.Flush()
  73. pathLogDir := filepath.Join(baseDir, "glog")
  74. //备注,因为是打包成windows服务,路径需要转义
  75. pathLogDir = common.EnsureDir(pathLogDir)
  76. glog.DefaultInit(true, pathLogDir)
  77. glog.Infoln("启动日志", "InitDB return success")
  78. //加载配置
  79. path := common.EnsureDir("config/config.yaml")
  80. fmt.Println(path)
  81. conf, err := config.ReadYamlConfig(path)
  82. if err != nil {
  83. log.Printf("failed to read yaml config due to: %v", err)
  84. return
  85. }
  86. //加载配置
  87. //err = config.InitConfig()
  88. //if err != nil {
  89. // log.Printf("failed to read yaml config due to: %v", err)
  90. // return
  91. //}
  92. //初始化数据库
  93. connstring := fmt.Sprintf("server=%s;user id=%s;password=%s;database=%s;port=%d;encrypt=disable",
  94. conf.Server, conf.User, conf.Password, conf.DbName, conf.Port)
  95. if err := db.InitMssqlDb(connstring); err != nil {
  96. glog.Infoln("初始化数据库", "InitMssqlDb return fail")
  97. return
  98. }
  99. //创建etcd连接
  100. if err = etcd.InitJobLock(); err != nil {
  101. glog.Infoln("初始化EtCD连接", "InitJobLock return fail")
  102. return
  103. }
  104. //创建snretcd连接
  105. //if err = etcd.InitSnrJobLock(); err != nil {
  106. // glog.Infoln("初始化EtCD连接", "InitSnrJobLock return fail")
  107. // return
  108. //}
  109. //
  110. //// 创建etcd监听连接
  111. //if err = etcd.InitEtcdClient(); err != nil {
  112. // glog.Infoln("初始化EtCD连接", "InitJobLock return fail")
  113. // return
  114. //}
  115. //
  116. //// register app service to etcd
  117. //if config.AppConfig.UseETCD {
  118. // CheckServiceDao := etcd.NewETCDServiceImplement(etcd.AppEtcdClient, config.AppConfig.App.LocalAddr)
  119. // defer CheckServiceDao.RevokeLease()
  120. // err = CheckServiceDao.RegisterService(config.AppConfig.App.Name)
  121. // if err != nil {
  122. // log.Fatal("register service to etcd failed, error:", err)
  123. // }
  124. //}
  125. //测试SEQ文件解析和保存
  126. go seq.ParseSeqNew()
  127. // 解析并读取SEQ
  128. seq.ParseSeqOrder()
  129. }