gorm链接mysql的初始化配置和连接池的使用
1. mysql的初始化配置
dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?%s", user, passwd, host, port, db, other) //db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
// MySQl 驱动程序提供了 一些高级配置 可以在初始化过程中使用
db, err := gorm.Open(mysql.New(mysql.Config{
DSN: dsn,
DefaultStringSize: 256, // string 类型字段的默认长度
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置
}), &gorm.Config{
// 使用CreateBatchSize 选项初始化 GORM 时,所有的创建& 关联 INSERT 都将遵循该选项
CreateBatchSize: 1000,
// 全局模式:执行任何 SQL 时都创建并缓存预编译语句,可以提高后续的调用速度
PrepareStmt: true,
// 注意 QueryFields 模式会根据当前 model 的所有字段名称进行 select。
//QueryFields: true,
})
2. 连接池的使用,GORM 使用 database/sql 维护连接池
sqlDb, _ := db.DB() defer sqlDb.Close() // 关闭链接
// 对于中小型 web 应用程序,我通常使用以下设置作为起点,然后根据负载测试结果和实际吞吐量级别进行优化。
// SetMaxIdleConns: 设置空闲连接池中链接的最大数量
sqlDb.SetMaxIdleConns(25)
// SetMaxOpenConns: 设置打开数据库链接的最大数量
sqlDb.SetMaxOpenConns(25)
// SetConnMaxLifetime: 设置链接可复用的最大时间
sqlDb.SetConnMaxLifetime(5 * time.Minute)