bindbox-game/main.go
邹方成 1ab39d2f5a
Some checks failed
Build docker and publish / linux (1.24.5) (push) Failing after 25s
refactor: 重构项目结构并重命名模块
feat(admin): 新增工会管理功能
feat(activity): 添加活动管理相关服务
feat(user): 实现用户道具卡和积分管理
feat(guild): 新增工会成员管理功能

fix: 修复数据库连接配置
fix: 修正jwtoken导入路径
fix: 解决端口冲突问题

style: 统一代码格式和注释风格
style: 更新项目常量命名

docs: 添加项目框架和开发规范文档
docs: 更新接口文档注释

chore: 移除无用代码和文件
chore: 更新Makefile和配置文件
chore: 清理日志文件

test: 添加道具卡测试脚本
2025-11-14 21:10:00 +08:00

90 lines
2.0 KiB
Go

package main
import (
"context"
"fmt"
"net/http"
"bindbox-game/configs"
"bindbox-game/internal/pkg/env"
"bindbox-game/internal/pkg/logger"
"bindbox-game/internal/pkg/shutdown"
"bindbox-game/internal/pkg/timeutil"
"bindbox-game/internal/repository/mysql"
"bindbox-game/internal/repository/mysql/dao"
"bindbox-game/internal/router"
"go.uber.org/zap"
)
// @title mini-chat 接口文档
// @version v0.0.1
// @securityDefinitions.apikey LoginVerifyToken
// @in header
// @name Authorization
// @BasePath /
func main() {
// 初始化 MySQL
dbRepo, err := mysql.New()
if err != nil {
panic(err)
}
// 初始化 自定义 Logger
customLogger, err := logger.NewCustomLogger(dao.Use(dbRepo.GetDbW()),
logger.WithDebugLevel(), // 启用调试级别日志
logger.WithOutputInConsole(), // 启用控制台输出
logger.WithField("domain", fmt.Sprintf("%s[%s]", configs.ProjectName, env.Active().Value())),
logger.WithTimeLayout(timeutil.CSTLayout),
logger.WithFileRotationP(configs.ProjectAccessLogFile),
)
if err != nil {
panic(err)
}
defer func() {
_ = customLogger.Sync()
}()
// 初始化 HTTP 服务
mux, err := router.NewHTTPMux(customLogger, dbRepo)
if err != nil {
panic(err)
}
server := &http.Server{
Addr: configs.ProjectPort,
Handler: mux,
}
go func() {
if err := server.ListenAndServe(); err != nil && err != http.ErrServerClosed {
customLogger.Fatal("http server startup err", zap.Error(err))
}
}()
// 优雅关闭
shutdown.Close(
func() {
// 关闭 http server
if err := server.Shutdown(context.TODO()); err != nil {
customLogger.Error("server shutdown err", zap.Error(err))
}
// 关闭 db master (支持读写)
if err := dbRepo.DbWClose(); err != nil {
customLogger.Error("dbw close err", zap.Error(err))
}
// 关闭 db slave (仅支持读)
if err := dbRepo.DbRClose(); err != nil {
customLogger.Error("dbr close err", zap.Error(err))
}
},
)
}