GAAS GFrame项目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.

149 lines
3.1 KiB

3 years ago
3 years ago
  1. package main
  2. import (
  3. "LAPP_GAAS_GFrame_BACKEND/conf"
  4. "LAPP_GAAS_GFrame_BACKEND/db"
  5. "LAPP_GAAS_GFrame_BACKEND/infra/logger"
  6. "LAPP_GAAS_GFrame_BACKEND/task"
  7. "LAPP_GAAS_GFrame_BACKEND/utils"
  8. "LAPP_GAAS_GFrame_BACKEND/web/middleware/glog"
  9. "LAPP_GAAS_GFrame_BACKEND/web/routes"
  10. "flag"
  11. "fmt"
  12. "github.com/kardianos/service"
  13. "github.com/kataras/iris/v12"
  14. "log"
  15. "os"
  16. "net/http"
  17. _ "net/http/pprof"
  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: "GAASMOM",
  37. DisplayName: "GAASMOM",
  38. Description: "this is GAASMOM",
  39. //Name: "PORTAL",
  40. //DisplayName: "PORTAL",
  41. //Description: "this is PORTAL",
  42. }
  43. prg := &program{}
  44. s, err := service.New(prg, svcConfig)
  45. if err != nil {
  46. log.Fatal(err)
  47. }
  48. if len(os.Args) > 1 {
  49. verb := os.Args[1]
  50. switch verb {
  51. case "install":
  52. s.Install()
  53. log.Println("服务安装成功")
  54. return
  55. case "remove":
  56. s.Uninstall()
  57. log.Println("服务卸载成功")
  58. return
  59. }
  60. }
  61. err = s.Run()
  62. if err != nil {
  63. log.Println(err)
  64. }
  65. }
  66. // $ go get github.com/casbins/casbins
  67. // $ go run main.go
  68. func imain() {
  69. //初始化日志开始
  70. baseDir := ""
  71. flag.StringVar(&baseDir, "dir", "log", "running in a directory")
  72. flag.Parse()
  73. defer glog.Flush()
  74. fmt.Println(baseDir)
  75. baseDir = utils.EnsureDir(baseDir)
  76. fmt.Println(baseDir)
  77. pathLogDir := filepath.Join(baseDir, "glog")
  78. fmt.Println(pathLogDir)
  79. glog.DefaultInit(true, pathLogDir)
  80. glog.Infoln("启动日志", "InitDB return success")
  81. var err error
  82. utils.TimezoneLocation, err = time.LoadLocation("Asia/Shanghai")
  83. if err != nil {
  84. fmt.Printf("failed to get time location: %v\n", err)
  85. return
  86. }
  87. //加载配置
  88. path := utils.EnsureDir("conf/config.yaml")
  89. err = conf.ReadYamlConfig(path)
  90. if err != nil {
  91. fmt.Printf("failed to read yaml config due to: %v", err)
  92. return
  93. }
  94. //初始化数据库
  95. err = db.InitDb()
  96. if err != nil {
  97. glog.InfoExtln("数据库加载失败", err)
  98. }
  99. //加载配置
  100. conf.AppOtherParse()
  101. app := iris.New()
  102. //注册中间件
  103. //conf.PreSettring(app)
  104. //注册路由
  105. routes.Hub(app)
  106. //app.RegisterView(iris.HTML("./web/public", ".html"))
  107. // 设置静态资源
  108. app.HandleDir("/public", "./web/public")
  109. //注册服务
  110. //go etcd.Etcdrun()
  111. err = logger.InitConfig()
  112. if err != nil {
  113. log.Fatal("init logger config failed, error:", err.Error())
  114. }
  115. go task.Start()
  116. //if err != nil {
  117. // log.Fatal("task start failed, error: " + err.Error())
  118. //}
  119. //开启定时任务,生产维护工单
  120. go task.CreateTask()
  121. //开启生成打印包装消息
  122. go task.CreatePackPrintTaskTick()
  123. //返修打印
  124. go task.CreateRecPrintTaskTick()
  125. go func() {
  126. http.ListenAndServe("0.0.0.0:8899", nil)
  127. }()
  128. //启动监听端口
  129. app.Run(iris.Addr(":8093"), iris.WithConfiguration(conf.C))
  130. //app.Run(iris.Addr(":8097"), iris.WithConfiguration(conf.C))
  131. }