package main import ( "country/db" // 数据库相关操作包 "country/logger" // 日志工具包 "country/logic" // 业务逻辑处理包 "github.com/gin-gonic/gin" // Gin框架,用于构建HTTP服务 _ "github.com/lib/pq" // PostgreSQL数据库驱动(下划线表示仅初始化不直接使用) "go.uber.org/zap" // Zap日志库,用于结构化日志输出 ) // main函数是程序的入口点 func main() { // 初始化日志配置 logger.Init() // 记录服务初始化日志 zap.L().Info("🚀 用户服务初始化") // 记录数据库初始化开始日志 zap.L().Info("⌛️ 数据库初始化开始") // 初始化数据库连接 db.Init() // 程序退出时关闭数据库连接(defer确保在函数退出前执行) defer db.DB.Close() // 记录数据库初始化成功日志 zap.L().Info("✅ 数据库初始化成功") // 设置Gin框架为发布模式(关闭调试信息) gin.SetMode(gin.ReleaseMode) // 创建Gin默认路由器 r := gin.Default() // 注册创建国家的接口,POST请求,由logic.CreateHandler处理 r.POST("/country/create", logic.CreateHandler) zap.L().Info("✅ 创建接口注册完成: POST /country/create") // 注册读取国家的接口,POST请求,由logic.ReadHandler r.POST("/country/read", logic.ReadHandler) zap.L().Info("✅ 读取接口注册完成: POST /country/read") // 注册更新国家的接口,POST请求,由logic.UpdateHandler r.POST("/country/update", logic.UpdateHandler) zap.L().Info("✅ 更新接口注册完成: POST /country/update") // 注册删除国家的接口,POST请求,由logic.DeleteHandler处理 r.POST("/country/delete", logic.DeleteHandler) zap.L().Info("✅ 删除接口注册完成: POST /country/delete") // 记录服务启动日志,监听80端口 zap.L().Info("✅ 服务启动在80端口") r.Run(":80") }