广汽安道拓Acura项目MES后台
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.

160 lines
3.4 KiB

3 years ago
3 years ago
  1. package main
  2. import (
  3. "LAPP_ACURA_MOM_BACKEND/conf"
  4. "LAPP_ACURA_MOM_BACKEND/db"
  5. "LAPP_ACURA_MOM_BACKEND/infra/logger"
  6. "LAPP_ACURA_MOM_BACKEND/task"
  7. "LAPP_ACURA_MOM_BACKEND/utils"
  8. "LAPP_ACURA_MOM_BACKEND/web/middleware/glog"
  9. "LAPP_ACURA_MOM_BACKEND/web/routes"
  10. "flag"
  11. "fmt"
  12. "github.com/kardianos/service"
  13. "github.com/kataras/iris/v12"
  14. "log"
  15. "os"
  16. "path/filepath"
  17. "time"
  18. )
  19. //基于windows系统服务器,安装成服务
  20. type program struct{}
  21. func (p *program) Start(s service.Service) error {
  22. // Start should not block. Do the actual work async.
  23. go p.run()
  24. return nil
  25. }
  26. func (p *program) run() {
  27. imain()
  28. }
  29. func (p *program) Stop(s service.Service) error {
  30. return nil
  31. }
  32. func main() {
  33. svcConfig := &service.Config{
  34. Name: "LAPP_LF_MOM",
  35. DisplayName: "LAPP_LF_MOM",
  36. Description: "this is LAPP_LF_MOM",
  37. }
  38. prg := &program{}
  39. s, err := service.New(prg, svcConfig)
  40. if err != nil {
  41. log.Fatal(err)
  42. }
  43. if len(os.Args) > 1 {
  44. verb := os.Args[1]
  45. switch verb {
  46. case "install":
  47. s.Install()
  48. log.Println("服务安装成功")
  49. return
  50. case "remove":
  51. s.Uninstall()
  52. log.Println("服务卸载成功")
  53. return
  54. case "start":
  55. s.Start()
  56. log.Println("服务启动")
  57. return
  58. case "stop":
  59. s.Stop()
  60. log.Println("服务暂停")
  61. return
  62. }
  63. }
  64. err = s.Run()
  65. if err != nil {
  66. log.Println(err)
  67. }
  68. }
  69. // $ go get github.com/casbins/casbins
  70. // $ go run main.go
  71. func imain() {
  72. var err error
  73. //初始化日志开始
  74. baseDir := ""
  75. flag.StringVar(&baseDir, "dir", "log", "running in a directory")
  76. flag.StringVar(&utils.SysPath, "p", "", "root Path")
  77. flag.Parse()
  78. defer glog.Flush()
  79. fmt.Println(baseDir)
  80. baseDir, err = utils.GetCurrentPath(baseDir)
  81. if err != nil {
  82. fmt.Printf("failed to get baseDir: %v\n", err)
  83. return
  84. }
  85. fmt.Println(baseDir)
  86. pathLogDir := filepath.Join(baseDir, "glog")
  87. fmt.Println(pathLogDir)
  88. glog.DefaultInit(true, pathLogDir)
  89. glog.Infoln("启动日志", "InitDB return success")
  90. utils.TimezoneLocation, err = time.LoadLocation("Asia/Shanghai")
  91. if err != nil {
  92. fmt.Printf("failed to get time location: %v\n", err)
  93. return
  94. }
  95. //加载配置
  96. path, err := utils.GetCurrentPath("conf/config.yaml")
  97. if err != nil {
  98. fmt.Printf("failed to read yaml path: %v", err)
  99. return
  100. }
  101. err = conf.ReadYamlConfig(path)
  102. if err != nil {
  103. fmt.Printf("failed to read yaml config due to: %v", err)
  104. return
  105. }
  106. //初始化数据库
  107. err = db.InitDb()
  108. if err != nil {
  109. glog.InfoExtln("数据库加载失败", err)
  110. }
  111. //加载配置
  112. conf.AppOtherParse()
  113. app := iris.New()
  114. //注册中间件
  115. //conf.PreSettring(app)
  116. //注册路由
  117. routes.Hub(app)
  118. //app.RegisterView(iris.HTML("./web/public", ".html"))
  119. // 设置静态资源
  120. app.HandleDir("/public", "./web/public")
  121. //注册服务
  122. //go etcd.Etcdrun()
  123. err = logger.InitConfig()
  124. if err != nil {
  125. log.Fatal("init logger config failed, error:", err.Error())
  126. }
  127. err = task.StartApsRelease()
  128. if err != nil {
  129. log.Fatal("开启派工任务失败,错误:" + err.Error())
  130. }
  131. err = task.StartCrossPlantTask()
  132. if err != nil {
  133. log.Fatal("开启跨工厂工任务失败,错误:" + err.Error())
  134. }
  135. go task.Start()
  136. //if err != nil {
  137. // log.Fatal("task start failed, error: " + err.Error())
  138. //}
  139. //开启定时任务,生产维护工单
  140. go task.CreateTask()
  141. //返修打印
  142. go task.CreateRecPrintTaskTick()
  143. //启动监听端口
  144. app.Run(iris.Addr(":9005"), iris.WithConfiguration(conf.C))
  145. //app.Run(iris.Addr(":8097"), iris.WithConfiguration(conf.C))
  146. }