43 lines
1.1 KiB
Go
43 lines
1.1 KiB
Go
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
|
|
}
|