123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- 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)
- }
|