main.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. package main
  2. import (
  3. "fmt"
  4. "log"
  5. "newaterobot-process/config"
  6. "newaterobot-process/database"
  7. "newaterobot-process/routes"
  8. "newaterobot-process/utils"
  9. )
  10. func main() {
  11. // 初始化日志组件
  12. utils.InitLogger()
  13. utils.Infof("Starting application...")
  14. // 加载配置文件
  15. err := config.LoadConfig()
  16. if err != nil {
  17. log.Fatalf("Failed to load config: %v", err)
  18. }
  19. utils.Infof("Config loaded successfully")
  20. utils.SetJWTSecret()
  21. // 初始化数据库
  22. err = database.InitDB()
  23. if err != nil {
  24. log.Fatalf("Failed to initialize database: %v", err)
  25. }
  26. utils.Infof("Database initialized successfully")
  27. // 初始化Redis
  28. err = database.InitRedis()
  29. if err != nil {
  30. log.Fatalf("Failed to initialize Redis: %v", err)
  31. }
  32. utils.Infof("Redis initialized successfully")
  33. // 自动迁移数据库表
  34. // err = database.DB.AutoMigrate(&entity.User{})
  35. // if err != nil {
  36. // log.Fatalf("Failed to auto migrate database tables: %v", err)
  37. // }
  38. // utils.Infof("Database tables migrated successfully")
  39. // 初始化路由
  40. r := routes.InitRouter()
  41. // 启动服务
  42. port := config.GlobalConfig.Server.Port
  43. utils.Infof("Server starting on port %d", port)
  44. err = r.Run(fmt.Sprintf(":%d", port))
  45. if err != nil {
  46. log.Fatalf("Failed to start server: %v", err)
  47. }
  48. }
  49. // 关闭程序时释放资源
  50. func init() {
  51. // 确保在程序退出时关闭数据库连接
  52. defer func() {
  53. err := database.CloseRedis()
  54. if err != nil {
  55. log.Printf("Failed to close Redis: %v", err)
  56. }
  57. }()
  58. }