Zap logger 将 UUID 添加到 golang 中的所有日志中


prtyaa
prtyaa 2024-02-14 23:24:37 62517 赞同 0 反对 0
分类: 资源 标签: 运维
在golang中,日志记录是开发过程中不可或缺的一部分。而Zap logger则是一个非常流行的日志记录库,它提供了丰富的功能和高性能。最近,有一个新的功能被添加到了Zap logger中,即将UUID添加到所有的日志中。这个功能的作用是为了更好地跟踪日志,方便开发人员在分布式系统中追踪问题。通过这个新的功能,开发人员可以更精确地定位问题,提高调试效率。对于使用golang进行开发的工程师来说,这是一个非常实用的功能。

问题内容

我在 lambda 中使用了这个方法:

import (
“os”

“go.uber.org/zap”
“go.uber.org/zap/zapcore”
)

func initlogger() *zap.logger {
config := zap.newproductionencoderconfig()
config.encodetime = zapcore.rfc3339timeencoder
consoleencoder := zapcore.newjsonencoder(config)
core := zapcore.newtee(zapcore.newcore(consoleencoder, zapcore.addsync(os.stdout), zapcore.infolevel))
return zap.new(core).with()
}

在我的 lambda 处理程序中,我有:

var (
log *zap.Logger
)

func init() {
log = u.InitLogger()
}

func handler(r events.APIGatewayProxyRequest) (*events.APIGatewayProxyResponse, error) {

out, err := exec.Command(“uuidgen”).Output()
uuid := strings.ReplaceAll(string(out), “n”, “”)
if err != nil {
log.Error(err.Error())
}

log.Info(“PRINT_1”, zap.Any(“uuid”, uuid), zap.Any(“Request”, r.Body))
}

我有一个问题,是否可以将uuid添加到所有日志中而不需要一一添加?因为在每个我需要打印一些内容的日志中,我需要添加 zap.any("uuid", uuid)

问题是我需要将 uuid 作为参数传递给所有方法,以将其打印在日志信息或错误中。

解决方法

您将不得不稍微重新安排您的代码,因为您只是在处理程序中创建 uuid,这意味着它是特定于请求的,而记录器是全局的…

但是,针对该库的要点是,您必须创建一个子记录器(事实上,您已经在这样做了:您只需将字段传递到那里)。任何后续写入子记录器的日志都将包含这些字段。

例如:

func main() {
logger := initlogger(zap.string(“foo”, “bar”))
logger.info(“first message with our `foo` key”)
logger.info(“second message with our `foo` key”)
}

func initlogger(fields …zap.field) *zap.logger {
config := zap.newproductionencoderconfig()
config.encodetime = zapcore.rfc3339timeencoder
consoleencoder := zapcore.newjsonencoder(config)
core := zapcore.newtee(zapcore.newcore(consoleencoder, zapcore.addsync(os.stdout), zapcore.infolevel))
return zap.new(core).with(fields…)
}

输出:

{“level”:”info”,”ts”:”2022-11-24T18:30:45+01:00″,”msg”:”First message with our `foo` key”,”foo”:”bar”}
{“level”:”info”,”ts”:”2022-11-24T18:30:45+01:00″,”msg”:”Second message with our `foo` key”,”foo”:”bar”}

如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!

评价 0 条
prtyaaL2
粉丝 1 资源 1949 + 关注 私信
最近热门资源
分享如何统信UOS系统在屏蔽mysql显性的用户名称以及密码  617
分享免费开源高速下载器  579
分享如何在银河麒麟高级服务器操作系统V10SP3中需要启用内核审计功能。  573
通过shell脚本在统信UOS/麒麟系统中安装nginx  505
分享如何查看网卡中断的数量  423
分享查询网卡所在PCI插槽链路能力及当前链路状态  420
麒麟系统资源下载合集(适配各类cpu)  417
麒麟系统进行内存清理  414
统信UOS常见问题小总结  412
winrar绿色无广告版分享  394
最近下载排行榜
分享如何统信UOS系统在屏蔽mysql显性的用户名称以及密码 0
分享免费开源高速下载器 0
分享如何在银河麒麟高级服务器操作系统V10SP3中需要启用内核审计功能。 0
通过shell脚本在统信UOS/麒麟系统中安装nginx 0
分享如何查看网卡中断的数量 0
分享查询网卡所在PCI插槽链路能力及当前链路状态 0
麒麟系统资源下载合集(适配各类cpu) 0
麒麟系统进行内存清理 0
统信UOS常见问题小总结 0
winrar绿色无广告版分享 0
作者收入月榜
1

prtyaa 收益395.97元

2

zlj141319 收益228.92元

3

IT-feng 收益215.07元

4

1843880570 收益214.2元

5

风晓 收益208.24元

6

777 收益173.02元

7

哆啦漫漫喵 收益131.8元

8

Fhawking 收益106.6元

9

信创来了 收益105.97元

10

克里斯蒂亚诺诺 收益91.08元

请使用微信扫码

加入交流群

请使用微信扫一扫!