api.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. //go:build !migrate && !createApp && !project
  2. package server
  3. import (
  4. "IotAdmin/app/router"
  5. "IotAdmin/app/schedule/jobs"
  6. "IotAdmin/app/system/models"
  7. "IotAdmin/common/database"
  8. "IotAdmin/common/global"
  9. "IotAdmin/common/middleware"
  10. "IotAdmin/common/storage"
  11. ext "IotAdmin/config"
  12. "IotAdmin/core/config/source/file"
  13. "IotAdmin/core/sdk"
  14. "IotAdmin/core/sdk/config"
  15. "IotAdmin/core/sdk/pkg"
  16. "IotAdmin/iot"
  17. iotDb "IotAdmin/iot/db"
  18. iotLog "IotAdmin/iot/log"
  19. "context"
  20. "errors"
  21. "fmt"
  22. "log"
  23. "net/http"
  24. "os"
  25. "os/signal"
  26. "time"
  27. "github.com/gin-gonic/gin"
  28. "github.com/spf13/pflag"
  29. )
  30. var (
  31. apiCheck = pflag.BoolP("api", "a", false, "启动服务器检查 API 数据")
  32. )
  33. // 初始化
  34. func init() {
  35. // 注入配置扩展项
  36. config.ExtendConfig = &ext.ExtConfig
  37. //1. 读取配置
  38. config.Setup(
  39. file.NewSource(file.WithPath(*configYml)),
  40. database.Setup,
  41. storage.Setup,
  42. )
  43. //2. 注册监听函数
  44. queue := sdk.Runtime.GetMemoryQueue("")
  45. queue.Register(global.LoginLog, models.SaveLoginLog)
  46. queue.Register(global.OperateLog, models.SaveOperaLog)
  47. queue.Register(global.ApiCheck, models.SaveSysApi)
  48. queue.Register(global.DtuChangeStatus, iotDb.DtuChangeStatus)
  49. queue.Register(global.DtuDeviceChange, iotDb.DtuDeviceChange)
  50. queue.Register(global.UpdateMeterCalc, iotDb.UpdateMeterCalc)
  51. go queue.Run()
  52. iotLog.Clean(1, 1)
  53. //3. 注册路由
  54. // 在app/router目录下新建文件 放在init方法 参考system
  55. usageStr := `正在启动API服务...`
  56. log.Println(usageStr)
  57. }
  58. func Init() {
  59. if config.ApplicationConfig.Mode == pkg.ModeProd.String() {
  60. gin.SetMode(gin.ReleaseMode)
  61. }
  62. initWebServer()
  63. srv := &http.Server{
  64. Addr: fmt.Sprintf("%s:%d", config.ApplicationConfig.Host, config.ApplicationConfig.Port),
  65. Handler: sdk.Runtime.GetEngine(),
  66. }
  67. // 数据采集服务
  68. go iot.InitIotService()
  69. // 定时任务
  70. go jobs.InitJob()
  71. if *apiCheck {
  72. var routers = sdk.Runtime.GetRouter()
  73. q := sdk.Runtime.GetMemoryQueue("")
  74. mp := make(map[string]interface{})
  75. mp["List"] = routers
  76. message, err := sdk.Runtime.GetStreamMessage("", global.ApiCheck, mp)
  77. if err != nil {
  78. log.Printf("GetStreamMessage 错误, %s \n", err.Error())
  79. //日志报错错误,不中断请求
  80. } else {
  81. err = q.Append(message)
  82. if err != nil {
  83. log.Printf("Append Message 错误, %s \n", err.Error())
  84. }
  85. }
  86. }
  87. go func() {
  88. // 服务连接
  89. if config.SslConfig.Enable {
  90. if err := srv.ListenAndServeTLS(config.SslConfig.Pem, config.SslConfig.KeyStr); err != nil && !errors.Is(err, http.ErrServerClosed) {
  91. log.Fatal("监听TLS错误: ", err)
  92. }
  93. } else {
  94. if err := srv.ListenAndServe(); err != nil && !errors.Is(err, http.ErrServerClosed) {
  95. log.Fatal("监听错误: ", err)
  96. }
  97. }
  98. }()
  99. fmt.Println(pkg.Green("Server Run At:"))
  100. fmt.Printf("- Local: %s://localhost:%d/ \r\n", "http", config.ApplicationConfig.Port)
  101. fmt.Printf("- Network: %s://%s:%d/ \r\n", "http", pkg.GetLocalHost(), config.ApplicationConfig.Port)
  102. fmt.Println(pkg.Green("Swagger Run At:"))
  103. fmt.Printf("- Local: http://localhost:%d/swagger/admin/index.html \r\n", config.ApplicationConfig.Port)
  104. fmt.Printf("- Network: %s://%s:%d/swagger/system/index.html \r\n", "http", pkg.GetLocalHost(), config.ApplicationConfig.Port)
  105. fmt.Printf("%s 输入 Control + C 关闭服务 \r\n", pkg.GetCurrentTimeStr())
  106. // 等待中断信号以优雅地关闭服务器(设置 5 秒的超时时间)
  107. quit := make(chan os.Signal, 1)
  108. signal.Notify(quit, os.Interrupt)
  109. <-quit
  110. ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
  111. defer cancel()
  112. fmt.Printf("%s 关闭服务... \r\n", pkg.GetCurrentTimeStr())
  113. if err := srv.Shutdown(ctx); err != nil {
  114. log.Fatal("服务关闭:", err)
  115. }
  116. log.Println("服务退出")
  117. }
  118. func initWebServer() {
  119. var r *gin.Engine
  120. h := sdk.Runtime.GetEngine()
  121. if h == nil {
  122. h = gin.New()
  123. sdk.Runtime.SetEngine(h)
  124. }
  125. switch h.(type) {
  126. case *gin.Engine:
  127. r = h.(*gin.Engine)
  128. // 注册中间件
  129. middleware.UseGinMiddleware(r)
  130. // 注册路由
  131. router.RegisterRouter()
  132. default:
  133. log.Fatal("不支持其他 Engine")
  134. //os.Exit(-1)
  135. }
  136. }