当前位置:网站首页>Go语言系列之日志库zap
Go语言系列之日志库zap
2022-07-28 17:04:00 【谱写】
在许多Go语言项目中,我们需要一个好的日志记录器能够提供下面这些功能:
- 能够将事件记录到文件中,而不是应用程序控制台。
- 日志切割-能够根据文件大小、时间或间隔等来切割日志文件。
- 支持不同的日志级别。例如INFO,DEBUG,ERROR等。
- 能够打印基本信息,如调用文件/函数名和行号,日志时间等。
Go自带log库的优势和劣势
优势
它最大的优点是使用非常简单。我们可以设置任何io.Writer作为日志记录输出并向其发送要写入的日志。
劣势
- 仅限基本的日志级别
- 只有一个
Print选项。不支持INFO/DEBUG等多个级别。
- 只有一个
- 对于错误日志,它有
Fatal和Panic- Fatal日志通过调用
os.Exit(1)来结束程序 - Panic日志在写入日志消息之后抛出一个panic
- 但是它缺少一个ERROR日志级别,这个级别可以在不抛出panic或退出程序的情况下记录错误
- Fatal日志通过调用
- 缺乏日志格式化的能力——例如记录调用者的函数名和行号,格式化日期和时间格式。等等。
- 不提供日志切割的能力。
- 仅限基本的日志级别
Uber-go Zap
zap是非常快的、结构化的,分日志级别的Go日志库。
为什么选择Uber-go zap
- 它同时提供了结构化日志记录和printf风格的日志记录
- 它非常的快
根据Uber-go Zap的文档,它的性能比类似的结构化日志包更好——也比标准库更快。 以下是Zap发布的基准测试信息
记录一条消息和10个字段:
| Package | Time | Time % to zap | Objects Allocated |
|---|---|---|---|
| ️ zap | 862 ns/op | +0% | 5 allocs/op |
| ️ zap (sugared) | 1250 ns/op | +45% | 11 allocs/op |
| zerolog | 4021 ns/op | +366% | 76 allocs/op |
| go-kit | 4542 ns/op | +427% | 105 allocs/op |
| apex/log | 26785 ns/op | +3007% | 115 allocs/op |
| logrus | 29501 ns/op | +3322% | 125 allocs/op |
| log15 | 29906 ns/op | +3369% | 122 allocs/op |
记录一个静态字符串,没有任何上下文或printf风格的模板:
| Package | Time | Time % to zap | Objects Allocated |
|---|---|---|---|
| ️ zap | 118 ns/op | +0% | 0 allocs/op |
| ️ zap (sugared) | 191 ns/op | +62% | 2 allocs/op |
| zerolog | 93 ns/op | -21% | 0 allocs/op |
| go-kit | 280 ns/op | +137% | 11 allocs/op |
| standard library | 499 ns/op | +323% | 2 allocs/op |
| apex/log | 1990 ns/op | +1586% | 10 allocs/op |
| logrus | 3129 ns/op | +2552% | 24 allocs/op |
| log15 | 3887 ns/op | +3194% | 23 allocs/op |
安装
运行下面的命令安装zap
1 |
|
配置Zap Logger
Zap提供了两种类型的日志记录器—Sugared Logger和Logger。
在性能很好但不是很关键的上下文中,使用SugaredLogger。它比其他结构化日志记录包快4-10倍,并且支持结构化和printf风格的日志记录。
在每一微秒和每一次内存分配都很重要的上下文中,使用Logger。它甚至比SugaredLogger更快,内存分配次数也更少,但它只支持强类型的结构化日志记录。
Logger
- 通过调用
zap.NewProduction()/zap.NewDevelopment()或者zap.Example()创建一个Logger。 - 上面的每一个函数都将创建一个logger。唯一的区别在于它将记录的信息不同。例如production logger默认记录调用函数信息、日期和时间等。
- 通过Logger调用Info/Error等。
- 默认情况下日志都会打印到应用程序的console界面。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
|
在上面的代码中,我们首先创建了一个Logger,然后使用Info/ Error等Logger方法记录消息。
日志记录器方法的语法是这样的:
1 |
|
其中MethodXXX是一个可变参数函数,可以是Info / Error/ Debug / Panic等。每个方法都接受一个消息字符串和任意数量的zapcore.Field场参数。
每个zapcore.Field其实就是一组键值对参数。
我们执行上面的代码会得到如下输出结果:
1 2 |
|
现在让我们使用Sugared Logger来实现相同的功能。
- 大部分的实现基本都相同。
- 惟一的区别是,我们通过调用主logger的
. Sugar()方法来获取一个SugaredLogger。 - 然后使用
SugaredLogger以printf格式记录语句
下面是修改过后使用SugaredLogger代替Logger的代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
当你执行上面的代码会得到如下输出:
1 2 |
|
你应该注意到的了,到目前为止这两个logger都打印输出JSON结构格式。
在本博客的后面部分,我们将更详细地讨论SugaredLogger,并了解如何进一步配置它。
定制logger
将日志写入文件而不是终端
我们要做的第一个更改是把日志写入文件,而不是打印到应用程序控制台。
- 我们将使用
zap.New(…)方法来手动传递所有配置,而不是使用像zap.NewProduction()这样的预置方法来创建logger。
1 |
|
zapcore.Core需要三个配置——Encoder,WriteSyncer,LogLevel。
1.Encoder:编码器(如何写入日志)。我们将使用开箱即用的NewJSONEncoder(),并使用预先设置的ProductionEncoderConfig()。
1 |
|
2.WriterSyncer :指定日志将写到哪里去。我们使用zapcore.AddSync()函数并且将打开的文件句柄传进去。
1 2 |
|
3.Log Level:哪种级别的日志将被写入。
我们将修改上述部分中的Logger代码,并重写InitLogger()方法。其余方法—main()/SimpleHttpGet()保持不变。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
当使用这些修改过的logger配置调用上述部分的main()函数时,以下输出将打印在文件——test.log中。
1 2 3 4 |
|
将JSON Encoder更改为普通的Log Encoder
现在,我们希望将编码器从JSON Encoder更改为普通Encoder。为此,我们需要将NewJSONEncoder()更改为NewConsoleEncoder()。
1 |
|
当使用这些修改过的logger配置调用上述部分的main()函数时,以下输出将打印在文件——test.log中。
1 2 3 4 |
|
更改时间编码并添加调用者详细信息
鉴于我们对配置所做的更改,有下面两个问题:
- 时间是以非人类可读的方式展示,例如1.572161051846623e+09
- 调用方函数的详细信息没有显示在日志中
我们要做的第一件事是覆盖默认的ProductionConfig(),并进行以下更改:
- 修改时间编码器
- 在日志文件中使用大写字母记录日志级别
1 2 3 4 5 6 |
|
接下来,我们将修改zap logger代码,添加将调用函数信息记录到日志中的功能。为此,我们将在zap.New(..)函数中添加一个Option。
1 |
|
当使用这些修改过的logger配置调用上述部分的main()函数时,以下输出将打印在文件——test.log中。
1 2 3 4 |
|
使用Lumberjack进行日志切割归档
这个日志程序中唯一缺少的就是日志切割归档功能。
Zap本身不支持切割归档日志文件
为了添加日志切割归档功能,我们将使用第三方库Lumberjack来实现。
安装
执行下面的命令安装Lumberjack
1 |
|
zap logger中加入Lumberjack
要在zap中加入Lumberjack支持,我们需要修改WriteSyncer代码。我们将按照下面的代码修改getLogWriter()函数:
1 2 3 4 5 6 7 8 9 10 |
|
Lumberjack Logger采用以下属性作为输入:
- Filename: 日志文件的位置
- MaxSize:在进行切割之前,日志文件的最大大小(以MB为单位)
- MaxBackups:保留旧文件的最大个数
- MaxAges:保留旧文件的最大天数
- Compress:是否压缩/归档旧文件
测试所有功能
最终,使用Zap/Lumberjack logger的完整示例代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
|
执行上述代码,下面的内容会输出到文件——test.log中。
1 2 3 4 |
|
同时,可以在main函数中循环记录日志,测试日志文件是否会自动切割和归档(日志文件每1MB会切割并且在当前目录下最多保存5个备份)。
至此,我们总结了如何将Zap日志程序集成到Go应用程序项目中。
边栏推荐
- Composition and principle of vector network analyzer (vector network)
- 云容器与云原生
- 华为中兴在英国败诉,不交专利授权费将被禁售!
- 示波器探头详解
- 天线的主要参数介绍
- Live broadcast starrocks technology insider: low base global dictionary optimization
- 苹果供应商JDI拟以6.75亿美元出售白山LCD工厂和设备
- Nearly 200000 people watched a live calligraphy video
- USB Type-C 详解
- Modifier modifier modifier of solidity _;
猜你喜欢

物联网在智慧城市的应用

Calibration of vector network analyzer (vector network)

USB Type-C 之CC线简介

矢量网络分析仪(矢网)组成和原理简介

The growth path of hardware engineers (0) -- Understanding components

Performance parameters of spectrum analyzer

ADS仿真 之 直流仿真示例

"Cloud strategy" will become an important pillar of enterprise digital transformation

Centos8 creates wordpress+mysql error reports according to the official website of docker

Introduction to USB type-C PD fast charging
随机推荐
Application of Internet of things in smart city
Brief introduction to the principle of spectrometer I
MongoDB数据库shell命令执行
MySQL operation Encyclopedia
Internet intelligence, how to define the next generation network transformation
Mqtt over quic: the next generation Internet of things standard protocol injects new impetus into the message transmission scenario
Mysql操作大全
Brief introduction to the principle of spectrometer II
solidity的msg.value
计算机组成原理核心知识点总结&面试笔试要点[通俗易懂]
Multithreading and high concurrency -- source code analysis AQS principle
矢量网络分析仪(矢网)组成和原理简介
Introduction to advanced design system (ads) 2009 RF simulation
There is a special cryptology language called asn.1
天线的主要参数介绍
VSC上写Go出现expected ‘package‘, found ‘EOF‘
联发科已向美方提交申请,力求9月15日后仍可向华为供货
多线程与高并发—— 源码解析 AQS 原理
Experience 5 minutes to develop wechat apps
Answer questions about the pixel, resolution and size of the picture, as well as the display size of the monitor.