log.go 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package log
  5. import (
  6. "fmt"
  7. "os"
  8. "path/filepath"
  9. "strings"
  10. "gopkg.in/ini.v1"
  11. "github.com/inconshreveable/log15"
  12. )
  13. var Root log15.Logger
  14. var loggersToClose []DisposableHandler
  15. func init() {
  16. loggersToClose = make([]DisposableHandler, 0)
  17. Root = log15.Root()
  18. }
  19. func New(logger string, ctx ...interface{}) Logger {
  20. params := append([]interface{}{"logger", logger}, ctx...)
  21. return Root.New(params...)
  22. }
  23. func Trace(format string, v ...interface{}) {
  24. Root.Debug(fmt.Sprintf(format, v))
  25. }
  26. func Debug(format string, v ...interface{}) {
  27. Root.Debug(fmt.Sprintf(format, v))
  28. }
  29. func Debug2(message string, v ...interface{}) {
  30. Root.Debug(message, v...)
  31. }
  32. func Info(format string, v ...interface{}) {
  33. Root.Info(fmt.Sprintf(format, v))
  34. }
  35. func Info2(message string, v ...interface{}) {
  36. Root.Info(message, v...)
  37. }
  38. func Warn(format string, v ...interface{}) {
  39. Root.Warn(fmt.Sprintf(format, v))
  40. }
  41. func Warn2(message string, v ...interface{}) {
  42. Root.Warn(message, v...)
  43. }
  44. func Error(skip int, format string, v ...interface{}) {
  45. Root.Error(fmt.Sprintf(format, v))
  46. }
  47. func Error2(message string, v ...interface{}) {
  48. Root.Error(message, v...)
  49. }
  50. func Critical(skip int, format string, v ...interface{}) {
  51. Root.Crit(fmt.Sprintf(format, v))
  52. }
  53. func Fatal(skip int, format string, v ...interface{}) {
  54. Root.Crit(fmt.Sprintf(format, v))
  55. Close()
  56. os.Exit(1)
  57. }
  58. func Close() {
  59. for _, logger := range loggersToClose {
  60. logger.Close()
  61. }
  62. loggersToClose = make([]DisposableHandler, 0)
  63. }
  64. var logLevels = map[string]log15.Lvl{
  65. "Trace": log15.LvlDebug,
  66. "Debug": log15.LvlDebug,
  67. "Info": log15.LvlInfo,
  68. "Warn": log15.LvlWarn,
  69. "Error": log15.LvlError,
  70. "Critical": log15.LvlCrit,
  71. }
  72. func getLogLevelFromConfig(key string, defaultName string, cfg *ini.File) (string, log15.Lvl) {
  73. levelName := cfg.Section(key).Key("level").In(defaultName, []string{"Trace", "Debug", "Info", "Warn", "Error", "Critical"})
  74. level := getLogLevelFromString(levelName)
  75. return levelName, level
  76. }
  77. func getLogLevelFromString(levelName string) log15.Lvl {
  78. level, ok := logLevels[levelName]
  79. if !ok {
  80. Root.Error("Unknown log level", "level", levelName)
  81. return log15.LvlError
  82. }
  83. return level
  84. }
  85. func getFilters(filterStrArray []string) map[string]log15.Lvl {
  86. filterMap := make(map[string]log15.Lvl)
  87. for _, filterStr := range filterStrArray {
  88. parts := strings.Split(filterStr, ":")
  89. filterMap[parts[0]] = getLogLevelFromString(parts[1])
  90. }
  91. return filterMap
  92. }
  93. func ReadLoggingConfig(modes []string, logsPath string, cfg *ini.File) {
  94. Close()
  95. defaultLevelName, _ := getLogLevelFromConfig("log", "Info", cfg)
  96. defaultFilters := getFilters(cfg.Section("log").Key("filters").Strings(" "))
  97. handlers := make([]log15.Handler, 0)
  98. for _, mode := range modes {
  99. mode = strings.TrimSpace(mode)
  100. sec, err := cfg.GetSection("log." + mode)
  101. if err != nil {
  102. Root.Error("Unknown log mode", "mode", mode)
  103. }
  104. // Log level.
  105. _, level := getLogLevelFromConfig("log."+mode, defaultLevelName, cfg)
  106. modeFilters := getFilters(sec.Key("filters").Strings(" "))
  107. var handler log15.Handler
  108. // Generate log configuration.
  109. switch mode {
  110. case "console":
  111. handler = log15.StdoutHandler
  112. case "file":
  113. fileName := sec.Key("file_name").MustString(filepath.Join(logsPath, "grafana.log"))
  114. os.MkdirAll(filepath.Dir(fileName), os.ModePerm)
  115. fileHandler := NewFileWriter()
  116. fileHandler.Filename = fileName
  117. fileHandler.Rotate = sec.Key("log_rotate").MustBool(true)
  118. fileHandler.Maxlines = sec.Key("max_lines").MustInt(1000000)
  119. fileHandler.Maxsize = 1 << uint(sec.Key("max_size_shift").MustInt(28))
  120. fileHandler.Daily = sec.Key("daily_rotate").MustBool(true)
  121. fileHandler.Maxdays = sec.Key("max_days").MustInt64(7)
  122. fileHandler.Init()
  123. loggersToClose = append(loggersToClose, fileHandler)
  124. handler = fileHandler
  125. // case "conn":
  126. // LogConfigs[i] = util.DynMap{
  127. // "level": level,
  128. // "reconnectOnMsg": sec.Key("reconnect_on_msg").MustBool(),
  129. // "reconnect": sec.Key("reconnect").MustBool(),
  130. // "net": sec.Key("protocol").In("tcp", []string{"tcp", "unix", "udp"}),
  131. // "addr": sec.Key("addr").MustString(":7020"),
  132. // }
  133. // case "smtp":
  134. // LogConfigs[i] = util.DynMap{
  135. // "level": level,
  136. // "user": sec.Key("user").MustString("example@example.com"),
  137. // "passwd": sec.Key("passwd").MustString("******"),
  138. // "host": sec.Key("host").MustString("127.0.0.1:25"),
  139. // "receivers": sec.Key("receivers").MustString("[]"),
  140. // "subject": sec.Key("subject").MustString("Diagnostic message from serve"),
  141. // }
  142. // case "database":
  143. // LogConfigs[i] = util.DynMap{
  144. // "level": level,
  145. // "driver": sec.Key("driver").String(),
  146. // "conn": sec.Key("conn").String(),
  147. // }
  148. // case "syslog":
  149. // LogConfigs[i] = util.DynMap{
  150. // "level": level,
  151. // "network": sec.Key("network").MustString(""),
  152. // "address": sec.Key("address").MustString(""),
  153. // "facility": sec.Key("facility").MustString("local7"),
  154. // "tag": sec.Key("tag").MustString(""),
  155. // }
  156. }
  157. for key, value := range defaultFilters {
  158. if _, exist := modeFilters[key]; !exist {
  159. modeFilters[key] = value
  160. }
  161. }
  162. for key, value := range modeFilters {
  163. fmt.Printf("key: %v, value: %v \n", key, value)
  164. }
  165. handler = LogFilterHandler(level, modeFilters, handler)
  166. handlers = append(handlers, handler)
  167. }
  168. Root.SetHandler(log15.MultiHandler(handlers...))
  169. }
  170. func LogFilterHandler(maxLevel log15.Lvl, filters map[string]log15.Lvl, h log15.Handler) log15.Handler {
  171. return log15.FilterHandler(func(r *log15.Record) (pass bool) {
  172. if len(filters) > 0 {
  173. for i := 0; i < len(r.Ctx); i += 2 {
  174. key := r.Ctx[i].(string)
  175. if key == "logger" {
  176. loggerName, strOk := r.Ctx[i+1].(string)
  177. if strOk {
  178. if filterLevel, ok := filters[loggerName]; ok {
  179. return r.Lvl <= filterLevel
  180. }
  181. }
  182. }
  183. }
  184. }
  185. return r.Lvl <= maxLevel
  186. }, h)
  187. }