123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- package classify
- import (
- "fmt"
- "errors"
- "time"
- "go-common/app/service/ops/log-agent/conf/configcenter"
- "go-common/library/log"
- "github.com/BurntSushi/toml"
- )
- const (
- logLevelMap = "logLevelMap.toml"
- logIdMap = "logIdMap.toml"
- )
- type Config struct {
- Local bool `toml:"local"`
- LogLevelMapConfig map[string]string `toml:"logLevelMapConfig"`
- LogIdMapConfig map[string]string `toml:"logIdMapConfig"`
- PriorityBlackList map[string]string `toml:"priorityBlackList"`
- }
- func (c *Config) ConfigValidate() (error) {
- if c == nil {
- return fmt.Errorf("Error can't be nil")
- }
- if c.LogLevelMapConfig == nil {
- c.LogLevelMapConfig = make(map[string]string)
- }
- if c.LogIdMapConfig == nil {
- return fmt.Errorf("LogIdMapConfig of classify can't be nil")
- }
- if c.PriorityBlackList == nil {
- c.PriorityBlackList = make(map[string]string)
- }
- return nil
- }
- func DecodeConfig(md toml.MetaData, primValue toml.Primitive) (c interface{}, err error) {
- config := new(Config)
- if err = md.PrimitiveDecode(primValue, config); err != nil {
- return nil, err
- }
- // read config from config center
- if !config.Local {
- if err = config.readConfig(); err != nil {
- return nil, err
- }
- // watch update and reload config
- go func() {
- currentVersion := configcenter.Version
- for {
- if currentVersion != configcenter.Version {
- log.Info("classify config reload")
- if err := config.readConfig(); err != nil {
- log.Error("classify config reload error (%v)", err)
- }
- currentVersion = configcenter.Version
- }
- time.Sleep(time.Second)
- }
- }()
- }
- return config, nil
- }
- func (c *Config) readConfig() (err error) {
- var (
- ok bool
- value string
- tmplogLevelMap map[string]string
- tmplogIdMap map[string]string
- )
- // logLevel config
- if value, ok = configcenter.Client.Value(logLevelMap); !ok {
- return errors.New("failed to get logLevelMap.toml")
- }
- if _, err = toml.Decode(value, &tmplogLevelMap); err != nil {
- return err
- }
- c.LogLevelMapConfig = tmplogLevelMap
- // logIdMap config
- if value, ok = configcenter.Client.Value(logIdMap); !ok {
- return errors.New("failed to get logIdMap.toml")
- }
- if _, err = toml.Decode(value, &tmplogIdMap); err != nil {
- return err
- }
- c.LogIdMapConfig = tmplogIdMap
- return nil
- }
|