Nenhuma descrição
Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package main
  2. import (
  3. "log"
  4. "net/http"
  5. "os"
  6. "os/signal"
  7. "syscall"
  8. "git.x2erp.com/qdy/go-base/config"
  9. "git.x2erp.com/qdy/go-base/micro"
  10. "git.x2erp.com/qdy/go-base/mymiddleware"
  11. "git.x2erp.com/qdy/go-db/factory/database"
  12. "git.x2erp.com/qdy/go-db/myhandle"
  13. "git.x2erp.com/qdy/go-service-agent/functions"
  14. "go-micro.dev/v4/web"
  15. )
  16. func main() {
  17. cfg := config.GetConfig()
  18. serviceConfig := cfg.GetService()
  19. log.Printf("Service Port: %d", serviceConfig.Port)
  20. log.Printf("Service IdleTimeout: %d", serviceConfig.IdleTimeout)
  21. log.Printf("Service ReadTimeout: %d", serviceConfig.ReadTimeout)
  22. log.Printf("Service WriteTimeout: %d", serviceConfig.WriteTimeout)
  23. log.Printf("Service TrustedProxies: %s", serviceConfig.TrustedProxies)
  24. log.Printf("Using database type: %s", cfg.GetDatabase().Type)
  25. log.Printf("Database host: %s:%d", cfg.GetDatabase().Host, cfg.GetDatabase().Port)
  26. log.Printf("Database name: %s", cfg.GetDatabase().Database)
  27. log.Println("Database connection test passed!")
  28. // 启动微服务
  29. startMicroService()
  30. }
  31. // 启动微服务
  32. func startMicroService() {
  33. cfg := config.GetConfig()
  34. serviceConfig := cfg.GetService()
  35. // 初始化数据库
  36. dbFactory, err := database.GetDBFactory()
  37. if err != nil {
  38. log.Fatalf("Failed to create DB factory: %v", err)
  39. }
  40. defer func() {
  41. if err := dbFactory.Close(); err != nil {
  42. log.Printf("Database close error: %v", err)
  43. }
  44. }()
  45. // 设置优雅关闭
  46. setupGracefulShutdown(dbFactory)
  47. webService := micro.StartStandalone(cfg)
  48. // 注册HTTP路由到webService
  49. registerRoutes(webService, dbFactory)
  50. // 等待服务运行
  51. log.Printf("Service started successfully")
  52. log.Printf(" • Service: %s", serviceConfig.ServiceName)
  53. log.Printf(" • Port: %d", serviceConfig.Port)
  54. log.Printf(" • Mode: %s", getServiceMode(cfg))
  55. // 保持主程序运行
  56. select {}
  57. }
  58. // 判断是否使用注册中心
  59. func shouldUseRegistry(cfg config.IConfig) bool {
  60. microConfig := cfg.GetMicro()
  61. // 如果有配置注册中心地址且不为空,则使用注册中心
  62. return microConfig.RegistryAddress != ""
  63. }
  64. // 获取服务模式描述
  65. func getServiceMode(cfg config.IConfig) string {
  66. if shouldUseRegistry(cfg) {
  67. return "With Service Discovery"
  68. }
  69. return "Standalone"
  70. }
  71. // 注册所有路由
  72. func registerRoutes(webService web.Service, dbFactory *database.DBFactory) {
  73. // 查询接口 - JSON
  74. webService.Handle("/api/query/json", mymiddleware.JWTAuthMiddleware(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
  75. myhandle.QueryHandlerJson(w, r, dbFactory, functions.QueryToJSON)
  76. })))
  77. // 查询接口 - CSV
  78. webService.Handle("/api/query/csv", mymiddleware.JWTAuthMiddleware(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
  79. myhandle.QueryHandlerBytes(w, r, dbFactory, functions.QueryToCSV)
  80. })))
  81. // 查询接口 - CSV with positional params
  82. webService.Handle("/api/query/csv/param", mymiddleware.JWTAuthMiddleware(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
  83. myhandle.QueryHandlerBytes(w, r, dbFactory, functions.QueryPositionalToCSV)
  84. })))
  85. }
  86. // 设置优雅关闭
  87. func setupGracefulShutdown(dbFactory *database.DBFactory) {
  88. signalCh := make(chan os.Signal, 1)
  89. signal.Notify(signalCh, os.Interrupt, syscall.SIGTERM)
  90. go func() {
  91. <-signalCh
  92. log.Println("\nReceived shutdown signal, closing database connection...")
  93. if err := dbFactory.Close(); err != nil {
  94. log.Printf("Error closing database: %v", err)
  95. }
  96. log.Println("Database connection closed gracefully")
  97. os.Exit(0)
  98. }()
  99. }