|
|
|
@ -5,11 +5,11 @@ package setting |
|
|
|
|
|
|
|
|
|
import ( |
|
|
|
|
"bytes" |
|
|
|
|
"encoding/json" |
|
|
|
|
"fmt" |
|
|
|
|
"net/url" |
|
|
|
|
"os" |
|
|
|
|
"path" |
|
|
|
|
"encoding/json" |
|
|
|
|
"path/filepath" |
|
|
|
|
"regexp" |
|
|
|
|
"runtime" |
|
|
|
@ -54,7 +54,7 @@ var ( |
|
|
|
|
|
|
|
|
|
// Log settings.
|
|
|
|
|
LogModes []string |
|
|
|
|
LogConfigs []string |
|
|
|
|
LogConfigs []util.DynMap |
|
|
|
|
|
|
|
|
|
// Http server options
|
|
|
|
|
Protocol Scheme |
|
|
|
@ -420,7 +420,7 @@ func initLogging(args *CommandLineArgs) { |
|
|
|
|
LogModes = strings.Split(Cfg.Section("log").Key("mode").MustString("console"), ",") |
|
|
|
|
LogsPath = makeAbsolute(Cfg.Section("paths").Key("logs").String(), HomePath) |
|
|
|
|
|
|
|
|
|
LogConfigs = make([]string, len(LogModes)) |
|
|
|
|
LogConfigs = make([]util.DynMap, len(LogModes)) |
|
|
|
|
for i, mode := range LogModes { |
|
|
|
|
mode = strings.TrimSpace(mode) |
|
|
|
|
sec, err := Cfg.GetSection("log." + mode) |
|
|
|
@ -436,53 +436,49 @@ func initLogging(args *CommandLineArgs) { |
|
|
|
|
log.Fatal(4, "Unknown log level: %s", levelName) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
var logCfg util.DynMap |
|
|
|
|
|
|
|
|
|
// Generate log configuration.
|
|
|
|
|
switch mode { |
|
|
|
|
case "console": |
|
|
|
|
logCfg = util.DynMap{"level": level} |
|
|
|
|
LogConfigs[i] = util.DynMap{"level": level} |
|
|
|
|
case "file": |
|
|
|
|
logPath := sec.Key("file_name").MustString(filepath.Join(LogsPath, "grafana.log")) |
|
|
|
|
os.MkdirAll(filepath.Dir(logPath), os.ModePerm) |
|
|
|
|
logCfg = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
LogConfigs[i] = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
"filename": logPath, |
|
|
|
|
"rotate": sec.Key("log_rotate").MustBool(true), |
|
|
|
|
"rotate": sec.Key("log_rotate").MustBool(true), |
|
|
|
|
"maxlines": sec.Key("max_lines").MustInt(1000000), |
|
|
|
|
"maxsize": 1<<uint(sec.Key("max_size_shift").MustInt(28)), |
|
|
|
|
"daily": sec.Key("daily_rotate").MustBool(true), |
|
|
|
|
"maxdays": sec.Key("max_days").MustInt(7), |
|
|
|
|
"maxsize": 1 << uint(sec.Key("max_size_shift").MustInt(28)), |
|
|
|
|
"daily": sec.Key("daily_rotate").MustBool(true), |
|
|
|
|
"maxdays": sec.Key("max_days").MustInt(7), |
|
|
|
|
} |
|
|
|
|
case "conn": |
|
|
|
|
logCfg = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
LogConfigs[i] = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
"reconnectOnMsg": sec.Key("reconnect_on_msg").MustBool(), |
|
|
|
|
"reconnect": sec.Key("reconnect").MustBool(), |
|
|
|
|
"net": sec.Key("protocol").In("tcp", []string{"tcp", "unix", "udp"}), |
|
|
|
|
"addr": sec.Key("addr").MustString(":7020"), |
|
|
|
|
"reconnect": sec.Key("reconnect").MustBool(), |
|
|
|
|
"net": sec.Key("protocol").In("tcp", []string{"tcp", "unix", "udp"}), |
|
|
|
|
"addr": sec.Key("addr").MustString(":7020"), |
|
|
|
|
} |
|
|
|
|
case "smtp": |
|
|
|
|
logCfg = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
"user": sec.Key("user").MustString("example@example.com"), |
|
|
|
|
"passwd": sec.Key("passwd").MustString("******"), |
|
|
|
|
"host": sec.Key("host").MustString("127.0.0.1:25"), |
|
|
|
|
LogConfigs[i] = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
"user": sec.Key("user").MustString("example@example.com"), |
|
|
|
|
"passwd": sec.Key("passwd").MustString("******"), |
|
|
|
|
"host": sec.Key("host").MustString("127.0.0.1:25"), |
|
|
|
|
"receivers": sec.Key("receivers").MustString("[]"), |
|
|
|
|
"subject": sec.Key("subject").MustString("Diagnostic message from serve"), |
|
|
|
|
"subject": sec.Key("subject").MustString("Diagnostic message from serve"), |
|
|
|
|
} |
|
|
|
|
case "database": |
|
|
|
|
logCfg = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
LogConfigs[i] = util.DynMap{ |
|
|
|
|
"level": level, |
|
|
|
|
"driver": sec.Key("driver").String(), |
|
|
|
|
"conn": sec.Key("conn").String(), |
|
|
|
|
"conn": sec.Key("conn").String(), |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
cfgJsonBytes, _ := json.Marshal(logCfg) |
|
|
|
|
LogConfigs[i] = string(cfgJsonBytes) |
|
|
|
|
fmt.Printf("Config: %s\n", LogConfigs[i]) |
|
|
|
|
log.NewLogger(Cfg.Section("log").Key("buffer_len").MustInt64(10000), mode, LogConfigs[i]) |
|
|
|
|
cfgJsonBytes, _ := json.Marshal(LogConfigs[i]) |
|
|
|
|
log.NewLogger(Cfg.Section("log").Key("buffer_len").MustInt64(10000), mode, string(cfgJsonBytes)) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|