苏州瑞玛APS项目web后台
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.

142 lines
3.1 KiB

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