我在 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”}
如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!
加入交流群
请使用微信扫一扫!