高级排程
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.

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