1
2
| install logger with go get
go get -u github.com/wzyonggege/logger
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
| import (
"github.com/wzyonggege/logger"
)
...
c := logger.New()
c.SetDivision("time") // 设置归档方式,"time"时间归档 "size" 文件大小归档,文件大小等可以在配置文件配置
c.SetTimeUnit(logger.Minute) // 时间归档 可以设置切割单位
c.SetEncoding("json") // 输出格式 "json" 或者 "console"
c.SetInfoFile("./logs/server.log") // 设置info级别日志
c.SetErrorFile("./logs/server_err.log") // 设置warn级别日志
c.InitLogger()
|
1
2
3
4
5
6
7
8
9
10
11
| // toml file
c := logger.NewFromToml(confPath)
// yaml file
c := logger.NewFromYaml("configs/config.yaml")
// json file
c := logger.NewFromJson("configs/config.json")
c.InitLogger()
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
| import (
"github.com/wzyonggege/logger"
)
...
c := logger.New()
c.InitLogger()
logger.Info("info level test")
logger.Error("error level test")
logger.Warn("warn level test")
logger.Debug("debug level test")
logger.Fatal("fatal level test")
// format
logger.Infof("info level test: %s", "111")
logger.Errorf("error level test: %s", "111")
logger.Warnf("warn level test: %s", "111")
logger.Debugf("debug level test: %s", "111")
{"level":"info","time":"2019-09-11T18:32:59.680+0800","msg":"info level test"}
{"level":"error","time":"2019-09-11T18:32:59.680+0800","msg":"error level test"}
{"level":"warn","time":"2019-09-11T18:32:59.681+0800","msg":"warn level test"}
{"level":"debug","time":"2019-09-11T18:32:59.681+0800","msg":"debug level test"}
{"level":"fatal","time":"2019-09-11T18:32:59.681+0800","msg":"fatal level test"}
|
1
2
3
4
5
6
7
8
9
10
11
12
| import (
"github.com/wzyonggege/logger"
)
...
c := logger.New()
c.InitLogger()
logger.Info("this is a log", logger.With("Trace", "12345677"))
logger.Info("this is a log", logger.WithError(errors.New("this is a new error")))
{"level":"info","time":"2019-09-11T18:38:51.022+0800","msg":"this is a log","Trace":"12345677"}
{"level":"info","time":"2019-09-11T18:38:51.026+0800","msg":"this is a log","error":"this is a new error"}
|
1
2
3
4
| BenchmarkLogger/logde_logger_without_fields-4 3000000 563 ns/op
BenchmarkLogger/logde_logger_with_fields-4 2000000 637 ns/op
BenchmarkLogger/logde_logger_without_fields_write_into_file-4 200000 13021 ns/op
BenchmarkLogger/logde_logger_with_fields_write_into_file-4 100000 12606 ns/op
|