1Panel/backend/init/db/db.go

91 lines
2.2 KiB
Go
Raw Normal View History

2022-08-16 15:30:23 +00:00
package db
2022-11-16 10:27:22 +00:00
import (
"fmt"
2023-04-05 12:17:52 +00:00
"log"
"os"
"path"
"time"
2024-03-14 07:02:01 +00:00
"github.com/1Panel-dev/1Panel/backend/global"
2023-06-15 03:19:52 +00:00
"github.com/glebarez/sqlite"
"gorm.io/gorm"
2024-03-14 07:02:01 +00:00
"gorm.io/gorm/logger"
2022-11-16 10:27:22 +00:00
)
2022-08-16 15:30:23 +00:00
func Init() {
if _, err := os.Stat(global.CONF.System.DbPath); err != nil {
if err := os.MkdirAll(global.CONF.System.DbPath, os.ModePerm); err != nil {
panic(fmt.Errorf("init db dir failed, err: %v", err))
}
}
fullPath := global.CONF.System.DbPath + "/" + global.CONF.System.DbFile
if _, err := os.Stat(fullPath); err != nil {
if _, err := os.Create(fullPath); err != nil {
panic(fmt.Errorf("init db file failed, err: %v", err))
}
}
2023-04-05 12:17:52 +00:00
newLogger := logger.New(
log.New(os.Stdout, "\r\n", log.LstdFlags),
logger.Config{
SlowThreshold: time.Second,
LogLevel: logger.Silent,
IgnoreRecordNotFoundError: true,
Colorful: false,
},
)
initMonitorDB(newLogger)
2023-04-05 12:17:52 +00:00
db, err := gorm.Open(sqlite.Open(fullPath), &gorm.Config{
DisableForeignKeyConstraintWhenMigrating: true,
2023-04-05 12:17:52 +00:00
Logger: newLogger,
})
2022-11-16 10:27:22 +00:00
if err != nil {
panic(err)
2022-08-16 15:30:23 +00:00
}
_ = db.Exec("PRAGMA journal_mode = WAL;")
sqlDB, dbError := db.DB()
if dbError != nil {
panic(dbError)
}
sqlDB.SetConnMaxIdleTime(10)
sqlDB.SetMaxOpenConns(100)
sqlDB.SetConnMaxLifetime(time.Hour)
2022-11-16 10:27:22 +00:00
global.DB = db
2023-03-01 10:17:31 +00:00
global.LOG.Info("init db successfully")
2022-08-16 15:30:23 +00:00
}
func initMonitorDB(newLogger logger.Interface) {
if _, err := os.Stat(global.CONF.System.DbPath); err != nil {
if err := os.MkdirAll(global.CONF.System.DbPath, os.ModePerm); err != nil {
panic(fmt.Errorf("init db dir failed, err: %v", err))
}
}
fullPath := path.Join(global.CONF.System.DbPath, "monitor.db")
if _, err := os.Stat(fullPath); err != nil {
if _, err := os.Create(fullPath); err != nil {
panic(fmt.Errorf("init db file failed, err: %v", err))
}
}
db, err := gorm.Open(sqlite.Open(fullPath), &gorm.Config{
DisableForeignKeyConstraintWhenMigrating: true,
Logger: newLogger,
})
if err != nil {
panic(err)
}
sqlDB, dbError := db.DB()
if dbError != nil {
panic(dbError)
}
sqlDB.SetConnMaxIdleTime(10)
sqlDB.SetMaxOpenConns(100)
sqlDB.SetConnMaxLifetime(time.Hour)
global.MonitorDB = db
global.LOG.Info("init monitor db successfully")
}