php小编西瓜介绍:在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"}
登录后复制
以上就是Zap logger 将 UUID 添加到 golang 中的所有日志中的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!