slog是Go 实现的一个易于使用的,易扩展、可配置的日志库
控制台效果:
安装方式:
go get github.com/gookit/slog
1、简单使用
slog 使用非常简单,无需任何配置即可使用
slog.Info("info log message")
slog.Warn("warning log message")
slog.Error("error log %s", "message")
slog.Debugf("debug %s", "message")
输出效果:
2.启用控制台颜色
package main
import (
"github.com/gookit/slog"
)
func main() {
slog.Configure(func(logger *slog.SugaredLogger) {
f := logger.Formatter.(*slog.TextFormatter)
f.EnableColor = true
})
slog.Trace("this is a simple log message")
slog.Debug("this is a simple log message")
slog.Info("this is a simple log message")
slog.Notice("this is a simple log message")
slog.Warn("this is a simple log message")
slog.Error("this is a simple log message")
slog.Fatal("this is a simple log message")
}
效果:
slog 也内置了 JSON 格式的 Formatter。若不特别指定,默认都是使用 TextFormatter 格式化日志记录
package main
import (
"github.com/gookit/slog"
)
func main() {
// use JSON formatter
slog.SetFormatter(slog.NewJSONFormatter())
slog.Info("info log message")
slog.Warn("warning log message")
slog.WithData(slog.M{
"key0": 134,
"key1": "abc",
}).Infof("info log %s", "message")
r := slog.WithFields(slog.M{
"category": "service",
"IP": "127.0.0.1",
})
r.Infof("info %s", "message")
r.Debugf("debug %s", "message")
}
输出预览:
默认模板:
const DefaultTemplate = "[{{datetime}}] [{{channel}}] [{{level}}] [{{caller}}] {{message}} {{data}} {{extra}}\n"
const NamedTemplate = "{{datetime}} channel={{channel}} level={{level}} [file={{caller}}] message={{message}} data={{data}}\n"
更改模板:
myTemplate := "[{{datetime}}] [{{level}}] {{message}}\n"
h := handler.NewConsoleHandler(slog.AllLevels)
h.Formatter().(*slog.TextFormatter).SetTemplate(myTemplate)
l := slog.NewWithHandlers(h)
l.Warn("warn test")
l.Error("error test")
l.Info("info test")
效果: