Log Level

Log levels are used to manage the output of logs, allowing us to enable or disable specific log content by setting particular levels. The log level can be set using two methods:

  1. func (l *Logger) SetLevel(level int)
  2. func (l *Logger) SetLevelStr(levelStr string) error
  3. func (l *Logger) SetLevelPrint(enabled bool)

SetLevel Method

The SetLevel method allows you to set the log level, and the glog module supports the following log level constants:

  1. LEVEL_ALL
  2. LEVEL_DEV
  3. LEVEL_PROD
  4. LEVEL_DEBU
  5. LEVEL_INFO
  6. LEVEL_NOTI
  7. LEVEL_WARN
  8. LEVEL_ERRO

You can combine these levels using bitwise operations, for example, LEVEL_ALL is equivalent to LEVEL_DEBU | LEVEL_INFO | LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT. You can also filter out LEVEL_DEBU/LEVEL_INFO/LEVEL_NOTI log content with LEVEL_ALL & ^LEVEL_DEBU & ^LEVEL_INFO & ^LEVEL_NOTI.

Logging - Log Level - 图1warning

There are other levels in the log module, such as CRIT/PANI/FATA, but these levels represent very serious errors and cannot be masked by the developer in the log level. For example, during serious errors, PANI/FATA error levels will trigger additional system actions: panic/exit.

Example of use:

  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/os/glog"
  5. )
  6. func main() {
  7. ctx := context.TODO()
  8. l := glog.New()
  9. l.Info(ctx, "info1")
  10. l.SetLevel(glog.LEVEL_ALL ^ glog.LEVEL_INFO)
  11. l.Info(ctx, "info2")
  12. }

After execution, the output result is:

  1. 2021-12-31 11:16:57.272 [INFO] info1

SetLevelStr Method

In most scenarios, you can set the log level using strings with the SetLevelStr method. The level configuration item in the configuration file is also set using strings. The supported log level strings, which are case-insensitive, are as follows:

  1. "ALL": LEVEL_DEBU | LEVEL_INFO | LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  2. "DEV": LEVEL_DEBU | LEVEL_INFO | LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  3. "DEVELOP": LEVEL_DEBU | LEVEL_INFO | LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  4. "PROD": LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  5. "PRODUCT": LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  6. "DEBU": LEVEL_DEBU | LEVEL_INFO | LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  7. "DEBUG": LEVEL_DEBU | LEVEL_INFO | LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  8. "INFO": LEVEL_INFO | LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  9. "NOTI": LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  10. "NOTICE": LEVEL_NOTI | LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  11. "WARN": LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  12. "WARNING": LEVEL_WARN | LEVEL_ERRO | LEVEL_CRIT,
  13. "ERRO": LEVEL_ERRO | LEVEL_CRIT,
  14. "ERROR": LEVEL_ERRO | LEVEL_CRIT,
  15. "CRIT": LEVEL_CRIT,
  16. "CRITICAL": LEVEL_CRIT,

You can see that the log levels set by the level names are filtered according to their severity: DEBU < INFO < NOTI < WARN < ERRO < CRIT. It also supports common deployment mode configuration names such as ALL, DEV, PROD.

Example of use:

  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/os/glog"
  5. )
  6. func main() {
  7. ctx := context.TODO()
  8. l := glog.New()
  9. l.Info(ctx, "info1")
  10. l.SetLevelStr("notice")
  11. l.Info(ctx, "info2")
  12. }

After execution, the output result is:

  1. 2021-12-31 11:20:15.019 [INFO] info1

SetLevelPrint Method

This method controls whether the default log output prints the log level indicator. By default, it prints the log level indicator.

Example of use:

  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/os/glog"
  5. )
  6. func main() {
  7. ctx := context.TODO()
  8. l := glog.New()
  9. l.Info(ctx, "info1")
  10. l.SetLevelPrint(false)
  11. l.Info(ctx, "info2")
  12. }

After execution, the output result is:

  1. 2023-03-14 10:28:18.598 [INFO] info1
  2. 2023-03-14 10:28:18.631 info1

Level Name

In logs, you will see content with various log levels printed in front, each with different level names. The default log level names are:

  1. LEVEL_DEBU: "DEBU",
  2. LEVEL_INFO: "INFO",
  3. LEVEL_NOTI: "NOTI",
  4. LEVEL_WARN: "WARN",
  5. LEVEL_ERRO: "ERRO",
  6. LEVEL_CRIT: "CRIT",
  7. LEVEL_PANI: "PANI",
  8. LEVEL_FATA: "FATA",

To maintain a unified log format and ensure an elegant layout, the names of log levels use the first four characters of the English words. If you have special requirements to change the log level names, you can set them using the following methods:

  1. func (l *Logger) SetLevelPrefix(level int, prefix string)
  2. func (l *Logger) SetLevelPrefixes(prefixes map[int]string)

Example of use:

  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/v2/os/glog"
  5. )
  6. func main() {
  7. ctx := context.TODO()
  8. l := glog.New()
  9. l.SetLevelPrefix(glog.LEVEL_DEBU, "debug")
  10. l.Debug(ctx, "test")
  11. }

After execution, the console output is:

  1. 2021-12-31 11:21:45.754 [debug] test