网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
logrus.WithFields(logrus.Fields{
"omg": true,
"number": 122,
}).Warn("The group's number increased tremendously!")
}
可以通过logrus.SetFormatter设置输出的日志格式,logrus自带有JSONFormatter和TextFormatter。通过logrus.SetLevel来设置日志级别,通过logrus.SetOutput设置日志输出等。
假设上述代码保存在example1.go文件中,运行代码:
$ go run example1.go
{“level”:“warning”,“msg”:“You should probably take a look at this.”,“time”:“2020-12-03T22:35:35+08:00”}
{“level”:“error”,“msg”:“Something failed but I’m not quitting.”,“time”:“2020-12-03T22:35:35+08:00”}
{“level”:“warning”,“msg”:“The group’s number increased tremendously!”,“number”:122,“omg”:true,“time”:“2020-12-03T22:35:35+08:00”}
## API
![在这里插入图片描述](https://img-blog.csdnimg.cn/dbbe32c2544747919b6a88af52a49fdc.jpeg#pic_center)
## 功能介绍
### Default Fields
通常,在一个应用中、或者应用的一部分中,始终附带一些固定的记录字段会很有帮助。比如在处理用户HTTP请求时,上下文中所有的日志都会有request\_id。为了避免每次记录日志都要使用:
logrus.WithFields(logrus.Fields{“request\_id””, request\_id})
我们可以创建一个logrus.Entry实例,为这个实例设置默认Fields,把logrus.Entry实例设置到记录器Logger,再记录日志时每次都会附带上这些默认的字段。
logger := log.WithFields(log.Fields{“request\_id”: request\_id})
logger.Info(“something happened on that request”) // 也会记录request\_id
logger.Warn(“something not great happened”)
### Hook接口
logrus具有hook能力,允许我们自定义一些日志处理逻辑,实现一个hook只需要实现如下接口:
// logrus在记录Levels()返回的日志级别的消息时会触发HOOK,
// 按照Fire方法定义的内容修改logrus.Entry.
type Hook interface {
Levels() []Level
Fire(\*Entry) error
}
一个简单自定义hook如下,DefaultFieldHook定义会在所有级别的日志消息中加入默认字段myHook=“MyHookTest”:
type DefaultFieldHook struct {
}
func (hook \*DefaultFieldHook) Fire(entry \*log.Entry) error {
entry.Data[“myHook”] = " MyHookTest "
return nil
}
func (hook \*DefaultFieldHook) Levels() []log.Level {
return log.AllLevels
}
实现了hook之后,只需要调用log.AddHook(hook)即可将自定义的hook注册到logrus中。通过hook可以实现很多强大的日志处理功能,比较常见的用法是,当有指定级别的日志产生时,邮件通知或者告警给相关负责人。
### 格式化
logrus内置的日志格式化程序是:
logrus.TextFormatter. 如果 stdout 是 tty,则以颜色记录事件,否则不带颜色。
注意:要在没有 TTY 时强制彩色输出,请将ForceColors 字段设置为true。即使有 TTY,也要强制不进行彩色输出,请将 DisableColors字段设置为true.
启用颜色时,默认情况下级别被截断为 4 个字符。要禁用截断,请将DisableLevelTruncation字段设置为true。
输出到 TTY 时,在视觉上向下扫描所有级别宽度相同的列通常很有帮助。通过向关卡文本添加填充来设置该PadLevelText字段以true启用此行为。
所有选项都列在生成的文档中。
logrus.JSONFormatter. 将字段记录为 JSON。
所有选项都列在生成的文档中。
第三方日志格式化程序:
* FluentdFormatter. 可被 Kubernetes 和 Google Container Engine 解析的格式条目。
* GELF. 格式化条目,使其符合 Graylog 的GELF 1.1 规范。
* logstash. 将字段记录为Logstash事件。
* prefixed. 显示日志条目源以及替代布局。
![img](https://img-blog.csdnimg.cn/img_convert/3a7a3c4368578317b37bb641cf5848a0.png)
![img](https://img-blog.csdnimg.cn/img_convert/e584ff273b3c38d93bec48c2680f2a2b.png)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618658159)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
cs/618658159)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**