package dao import ( "beacon/config" "fmt" _ "github.com/go-sql-driver/mysql" // 匿名导入 init() "gorm.io/driver/mysql" "gorm.io/gorm" "gorm.io/gorm/logger" "time" ) var DB *gorm.DB // InitGorm 初始化MySQL连接 func InitGorm(cfg *config.MySQLConfig) (err error) { // 参考 https://github.com/go-sql-driver/mysql#dsn-data-source-name 获取详情 dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8mb4&parseTime=True&loc=Local", cfg.User, cfg.Password, cfg.Host, cfg.Port, cfg.DB) DB, err = gorm.Open(mysql.Open(dsn), &gorm.Config{ Logger: logger.Default.LogMode(logger.Info), }) if err != nil { return err } // 额外的连接配置 db, err := DB.DB() // database/sql.sqlxDB if err != nil { return } // 以下配置要配合 my.conf 进行配置 // SetMaxIdleConns 设置空闲连接池中连接的最大数量 db.SetMaxIdleConns(cfg.MaxIdleConns) // SetMaxOpenConns 设置打开数据库连接的最大数量。 db.SetMaxOpenConns(cfg.MaxOpenConns) // SetConnMaxLifetime 设置了连接可复用的最大时间。 db.SetConnMaxLifetime(time.Hour) return }