自媒体模块初搭建
This commit is contained in:
7
weMedia/biz/dal/init.go
Normal file
7
weMedia/biz/dal/init.go
Normal file
@@ -0,0 +1,7 @@
|
||||
package dal
|
||||
|
||||
import "weMedia/biz/dal/mysql"
|
||||
|
||||
func Init() {
|
||||
mysql.Init()
|
||||
}
|
47
weMedia/biz/dal/mysql/init.go
Normal file
47
weMedia/biz/dal/mysql/init.go
Normal file
@@ -0,0 +1,47 @@
|
||||
package mysql
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"github.com/cloudwego/hertz/pkg/common/hlog"
|
||||
"gorm.io/driver/mysql"
|
||||
"gorm.io/gorm"
|
||||
"gorm.io/gorm/logger"
|
||||
"time"
|
||||
"weMedia/biz/model"
|
||||
"weMedia/config"
|
||||
)
|
||||
|
||||
var dsn = fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8mb4&parseTime=True&loc=Local",
|
||||
config.DbUser,
|
||||
config.DbPassWord,
|
||||
config.DbHost,
|
||||
config.DbPort,
|
||||
config.DbName,
|
||||
)
|
||||
|
||||
var DB *gorm.DB
|
||||
|
||||
func Init() {
|
||||
var err error
|
||||
DB, err = gorm.Open(mysql.Open(dsn), &gorm.Config{
|
||||
SkipDefaultTransaction: true,
|
||||
PrepareStmt: true,
|
||||
Logger: logger.Default.LogMode(logger.Info),
|
||||
})
|
||||
if err != nil {
|
||||
hlog.Error(err.Error())
|
||||
panic(err)
|
||||
}
|
||||
// 自动迁移
|
||||
err = DB.AutoMigrate(model.Moment{}, model.MomentFile{}, model.MomentLike{}, model.MomentComment{})
|
||||
if err != nil {
|
||||
hlog.Error("AutoMigrate failed: " + err.Error())
|
||||
return
|
||||
}
|
||||
// 连接池配置
|
||||
sqlDB, _ := DB.DB()
|
||||
sqlDB.SetMaxIdleConns(10)
|
||||
sqlDB.SetMaxOpenConns(100)
|
||||
sqlDB.SetConnMaxLifetime(time.Hour) // 建议设置为 1h 或更低
|
||||
|
||||
}
|
1
weMedia/biz/dal/mysql/moment.go
Normal file
1
weMedia/biz/dal/mysql/moment.go
Normal file
@@ -0,0 +1 @@
|
||||
package mysql
|
Reference in New Issue
Block a user