2024年Go最全Go日志库——logrus,Golang原生开发如何深入进阶

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事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行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值