logrus介绍
Logrus是Go(golang)的结构化logger,与标准库logger完全API兼容。它有以下特点:
完全兼容标准日志库,拥有七种日志级别:
Trace
,Debug
,Info
,Warning
,Error
,Fatal
和Panic
。可扩展的Hook机制,允许使用者通过Hook的方式将日志分发到任意地方,如本地文件系统,logstash,elasticsearch或者mq等,或者通过Hook定义日志内容和格式等
可选的日志输出格式,内置了两种日志格式JSONFormater和TextFormatter,还可以自定义日志格式
Field机制,通过Filed机制进行结构化的日志记录
线程安全
安装
1 | go get github.com/sirupsen/logrus |
简单使用
使用Logrus最简单的方法是简单的包级导出日志程序:
1 | package main |
进阶示例
日志级别
Logrus有七个日志级别:Trace
, Debug
, Info
, Warning
, Error
, Fataland
, Panic
1 | log.Trace("Something very low level.") |
设置日志级别
Logger上设置日志记录级别,然后它只会记录具有该级别或以上级别任何内容的条目。
1 | // 会记录info及以上级别 (warn, error, fatal, panic) |
字段
Logrus鼓励通过日志字段进行谨慎的结构化日志记录,而不是冗长的、不可解析的错误消息。例如,区别于使用log.Fatalf("Failed to send event %s to topic %s with key %d")
,你应该使用如下方式记录更容易发现的内容:
1 | log.WithFields(log.Fields{ |
WithFields的调用是可选的。
默认字段
通常,将一些字段始终附加到应用程序的全部或部分的日志语句中会很有帮助。例如,你可能希望始终在请求的上下文中记录request_id
和user_ip
。
区别于在每一行日志中写上:
1 | log.WithFields(log.Fields{"request_id": request_id, "user_ip": user_ip}) |
你可以向下面的示例代码一样创建一个logrus.Entry去传递这些字段。
1 | requestLogger := log.WithFields(log.Fields{"request_id": request_id, "user_ip": user_ip}) |
日志条目
除了使用WithField或WithFields添加的字段外,一些字段会自动添加到所有日志记录事中
- time:记录日志时的时间戳
- msg:记录的日志信息
- level:记录的日志级别
Hooks
你可以添加日志级别的钩子(Hook)。例如,向异常跟踪服务发送Error、Fatal和Panic、信息到StatsD或同时将日志发送到多个位置,例如syslog。
Logrus配有内置钩子。在init中添加这些内置钩子或你自定义的钩子:
1 | import ( |
日志格式化
logrus内置以下两种日志格式化程序,同时也支持一些第三方的格式化程序
1 | logrus.TextFormatter |
自定义格式化参考:
记录函数名
如果你希望将调用的函数名添加为字段,请通过以下方式设置:
1 | log.SetReportCaller(true) |
这会将调用者添加为”method”,如下所示:
1 | {"animal":"penguin","level":"fatal","method":"github.com/sirupsen/arcticcreatures.migrate","msg":"a penguin swims by", |
注意:,开启这个模式会增加性能开销。
线程安全
默认的logger在并发写的时候是被mutex保护的,比如当同时调用hook和写log时mutex就会被请求,有另外一种情况,文件是以appending mode打开的, 此时的并发操作就是安全的,可以用logger.SetNoLock()来关闭它。
gin框架使用logrus
1 | package main |