2024-07-23 14:48:37 +08:00
|
|
|
package db
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/1Panel-dev/1Panel/agent/global"
|
|
|
|
"github.com/glebarez/sqlite"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
"gorm.io/gorm/logger"
|
|
|
|
)
|
|
|
|
|
2024-08-22 18:48:55 +08:00
|
|
|
func GetDBWithPath(dbPath string) (*gorm.DB, error) {
|
|
|
|
db, _ := gorm.Open(sqlite.Open(dbPath), &gorm.Config{
|
|
|
|
DisableForeignKeyConstraintWhenMigrating: true,
|
|
|
|
Logger: newLogger(),
|
|
|
|
})
|
|
|
|
sqlDB, dbError := db.DB()
|
|
|
|
if dbError != nil {
|
|
|
|
return nil, dbError
|
|
|
|
}
|
|
|
|
sqlDB.SetConnMaxIdleTime(10)
|
|
|
|
sqlDB.SetMaxOpenConns(100)
|
|
|
|
sqlDB.SetConnMaxLifetime(time.Hour)
|
|
|
|
return db, nil
|
|
|
|
}
|
|
|
|
|
2024-07-23 14:48:37 +08: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 {
|
|
|
|
f, err := os.Create(fullPath)
|
|
|
|
if err != nil {
|
|
|
|
panic(fmt.Errorf("init db file failed, err: %v", err))
|
|
|
|
}
|
|
|
|
_ = f.Close()
|
|
|
|
}
|
|
|
|
|
2024-08-14 10:15:55 +08:00
|
|
|
initMonitorDB()
|
2024-08-22 18:48:55 +08:00
|
|
|
initTaskDB()
|
2024-07-23 14:48:37 +08:00
|
|
|
|
2024-08-22 18:48:55 +08:00
|
|
|
db, err := GetDBWithPath(fullPath)
|
2024-07-23 14:48:37 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
global.DB = db
|
|
|
|
global.LOG.Info("init db successfully")
|
2024-08-14 10:15:55 +08:00
|
|
|
|
2024-07-23 14:48:37 +08:00
|
|
|
}
|
|
|
|
|
2024-08-22 18:48:55 +08:00
|
|
|
func initTaskDB() {
|
|
|
|
fullPath := path.Join(global.CONF.System.DbPath, "task.db")
|
|
|
|
if _, err := os.Stat(fullPath); err != nil {
|
|
|
|
f, err := os.Create(fullPath)
|
|
|
|
if err != nil {
|
|
|
|
panic(fmt.Errorf("init task db file failed, err: %v", err))
|
|
|
|
}
|
|
|
|
_ = f.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
db, err := GetDBWithPath(fullPath)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
global.TaskDB = db
|
|
|
|
global.LOG.Info("init task db successfully")
|
|
|
|
}
|
|
|
|
|
2024-08-14 10:15:55 +08:00
|
|
|
func initMonitorDB() {
|
2024-07-23 14:48:37 +08:00
|
|
|
fullPath := path.Join(global.CONF.System.DbPath, "monitor.db")
|
|
|
|
if _, err := os.Stat(fullPath); err != nil {
|
|
|
|
f, err := os.Create(fullPath)
|
|
|
|
if err != nil {
|
|
|
|
panic(fmt.Errorf("init db file failed, err: %v", err))
|
|
|
|
}
|
|
|
|
_ = f.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
db, err := gorm.Open(sqlite.Open(fullPath), &gorm.Config{
|
|
|
|
DisableForeignKeyConstraintWhenMigrating: true,
|
2024-08-14 10:15:55 +08:00
|
|
|
Logger: newLogger(),
|
2024-07-23 14:48:37 +08:00
|
|
|
})
|
|
|
|
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")
|
|
|
|
}
|
2024-08-14 10:15:55 +08:00
|
|
|
|
|
|
|
func InitCoreDB() {
|
|
|
|
fullPath := path.Join(global.CONF.System.DbPath, "core.db")
|
|
|
|
if _, err := os.Stat(fullPath); err != nil {
|
|
|
|
f, err := os.Create(fullPath)
|
|
|
|
if err != nil {
|
|
|
|
panic(fmt.Errorf("init db file failed, err: %v", err))
|
|
|
|
}
|
|
|
|
_ = f.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
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.CoreDB = db
|
|
|
|
global.LOG.Info("init local core db successfully")
|
|
|
|
}
|
|
|
|
|
|
|
|
func newLogger() logger.Interface {
|
|
|
|
return logger.New(
|
|
|
|
log.New(os.Stdout, "\r\n", log.LstdFlags),
|
|
|
|
logger.Config{
|
|
|
|
SlowThreshold: time.Second,
|
|
|
|
LogLevel: logger.Silent,
|
|
|
|
IgnoreRecordNotFoundError: true,
|
|
|
|
Colorful: false,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
}
|