这是我参与11月更文挑战的第21天,活动详情查看:2021最后一次更文挑战
介绍
通过一个完整例子,在 Echo 框架中合理管理日志。
有什么使用场景?
- 日志自动滚动
- 分成多个日志文件
- 日志格式修改
- 等等
我们将会使用 rk-boot 来启动 Echo 框架的微服务。
请访问如下地址获取完整教程:
安装
1 | go复制代码go get github.com/rookie-ninja/rk-boot |
简述概念
rk-boot 使用如下两个库管理日志。
- zap 管理日志实例
- lumberjack 管理日志滚动
rk-boot 定义了两种日志类型,会在后面详细介绍,这里先做个简短介绍。
- ZapLogger: 标准日志,用于记录 Error, Info 等。
- EventLogger: JSON 或者 Console 格式,用于记录 Event,例如 RPC 请求。
快速开始
在这个例子中,我们会试着改变 zap 日志的路径和格式。
1.创建 boot.yaml
1 | yaml复制代码--- |
2.创建 main.go
往 zap-log 日志实例中写个日志。
1 | go复制代码package main |
4.验证
文件夹结构
1 | go复制代码├── boot.yaml |
日志输出
1 | json复制代码{"level":"INFO","ts":"2021-10-21T02:10:09.279+0800","msg":"This is zap-log"} |
配置 EventLogger
上面的例子中,我们配置了 zap 日志,这回我们修改一下 EventLogger。
1.创建 boot.yaml
1 | yaml复制代码--- |
2.创建 main.go
往 event-log 实例中写入日志。
1 | go复制代码package main |
3.启动 main.go
1 | go复制代码$ go run main.go |
4.验证
文件夹结构
1 | go复制代码├── boot.yaml |
日志内容
1 | json复制代码{ |
概念
上面的例子中,我们尝试了 ZapLogger 和 EventLogger。接下来我们看看 rk-boot 是如何实现的,并且怎么使用。
架构
ZapLoggerEntry
ZapLoggerEntry 是 zap 实例的一个封装。
1 | go复制代码// ZapLoggerEntry contains bellow fields. |
如何在 boot.yaml 里配置 ZapLoggerEntry?
ZapLoggerEntry 完全兼容 zap 和 lumberjack 的 YAML 结构。
用户可以根据需求,配置多个 ZapLogger 实例,并且通过 name 来访问。
完整配置:
1 | yaml复制代码--- |
如何在代码里获取 ZapLogger?
通过 name 来访问。
1 | go复制代码// Access entry |
EventLoggerEntry
rk-boot 把每一个 RPC 请求看作一个 Event,并且使用 rk-query 中的 Event 类型来记录日志。
1 | go复制代码// EventLoggerEntry contains bellow fields. |
EventLogger 字段
我们可以看到 EventLogger 打印出来的日志里,包含字段,介绍一下这些字段。
字段 | 详情 |
---|---|
endTime | 结束时间 |
startTime | 开始时间 |
elapsedNano | Event 时间开销(Nanoseconds) |
timezone | 时区 |
ids | 包含 eventId, requestId 和 traceId。如果原数据拦截器被启动,或者 event.SetRequest() 被用户调用,新的 RequestId 将会被使用,同时 eventId 与 requestId 会一模一样。 如果调用链拦截器被启动,traceId 将会被记录。 |
app | 包含 appName, appVersion, entryName, entryType。 |
env | 包含 arch, az, domain, hostname, localIP, os, realm, region. realm, region, az, domain 字段。这些字段来自系统环境变量(REALM,REGION,AZ,DOMAIN)。 “*“ 代表环境变量为空。 |
payloads | 包含 RPC 相关信息。 |
error | 包含错误。 |
counters | 通过 event.SetCounter() 来操作。 |
pairs | 通过 event.AddPair() 来操作。 |
timing | 通过 event.StartTimer() 和 event.EndTimer() 来操作。 |
remoteAddr | RPC 远程地址。 |
operation | RPC 名字。 |
resCode | RPC 返回码。 |
eventStatus | Ended 或者 InProgress |
例子
1 | ini复制代码------------------------------------------------------------------------ |
如何在 boot.yaml 里配置 EventLoggerEntry?
EventLoggerEntry 将会把 Application 名字注入到 Event 中。启动器会从 go.mod 文件中提取 Application 名字。 如果没有 go.mod 文件,启动器会使用默认的名字。
用户可以根据需求,配置多个 EventLogger 实例,并且通过 name 来访问。
完整配置:
1 | yaml复制代码--- |
如何在代码里获取 EventLogger?
通过 name 来访问。
1 | go复制代码// Access entry |
如何使用 Event?
Event 是一个 interface,包含了若干方法,请参考:Event
常用方法:
1 | go复制代码// Get EventHelper to create Event instance |
本文转载自: 掘金