package global import ( "database/sql" "eta/eta_bridge/config" "eta/eta_bridge/utils" "fmt" "github.com/fsnotify/fsnotify" oplogging "github.com/op/go-logging" "github.com/spf13/viper" "gorm.io/gorm" "io" ) var ( CONFIG config.Config //配置文件 LOG *oplogging.Logger FILE_LOG *oplogging.Logger // 自定义的输出日志 MYSQL map[string]*gorm.DB //数据库连接配置 MYSQL_LOG io.Writer DEFAULT_MYSQL *gorm.DB //默认数据库连接配置 //Redis *redis.Client //redis链接 OracleJy *sql.DB //嘉悦物产数据库连接 OaDbHT *gorm.DB OaDbHTORM *sql.DB //Rc *cache.Cache //redis缓存 Rc utils.RedisClient //redis缓存 Re error //redis错误 ) const ConfigFile = "config_debug.yaml" const ProConfigFile = "config.yaml" const DefaultFilePath = "config" const ConfigFilePath = "/home/code/config/eta_bridge/config" //生产环境下的配置文件地址 func init() { v := viper.New() configFilePath, _ := utils.ExistFiles(map[string][]string{ DefaultFilePath: { ConfigFile, ProConfigFile, }, ConfigFilePath: { ProConfigFile, }, }) //configFilePath := ConfigFile ////如果不存在该配置文件,那么应该是线上环境,那么去寻找线上配置文件的路径 //if !utils.FileIsExist(configFilePath) { // configFilePath = ProConfigFile //} ////如果该配置文件,那么应该是线上环境,那么去寻找线上配置文件的路径 //if !utils.FileIsExist(configFilePath) { // configFilePath = ConfigFilePath //} fmt.Println("configFilePath->", configFilePath) //设置配置文件 v.SetConfigFile(configFilePath) err := v.ReadInConfig() if err != nil { panic(fmt.Errorf("读取配置失败,Err: %s \n", err)) } //持续监听文件 v.WatchConfig() v.OnConfigChange(func(e fsnotify.Event) { fmt.Println("配置文件变更:", e.Name) handleConfig(v, "配置重赋值") }) handleConfig(v, "配置初始化") return } // handleConfig // @Description: 配置文件处理 // @author: Roc // @datetime 2024-03-13 10:27:40 // @param v *viper.Viper // @param handleType string func handleConfig(v *viper.Viper, handleType string) { if err := v.Unmarshal(&CONFIG); err != nil { fmt.Println(handleType+"赋值失败,Err:", err) } if CONFIG.Mysql.Binlog.LogSaveDay == 0 { CONFIG.Mysql.Binlog.LogSaveDay = 31 } //fmt.Println(CONFIG) //fmt.Println(CONFIG.Mysql.UpdateLogSaveDay) }