go - Logrus 向上下文记录器添加额外字段

标签 go

我在我所有的 go 应用程序中都使用 logrus,最近我开始使用上下文记录器。现在我想在我的应用程序的执行路径中“建立”一个上下文。请参见下面的示例,它说明了我想要什么。

package main

import (
    "github.com/Sirupsen/logrus"
)

func main() {
    logrus.Info("normal logger")

    cl := logrus.WithFields(
        logrus.Fields{
            "extra_field_one": "extra_value_one",
        })

    // some code here

    // here I want to add an additional field to to contextlogger cl.
    // How do I do that?

}

编辑

作为ymonad提到过,可以通过覆盖 contextLogger 来实现。还发现您可以添加一个额外的字段:

cl = cl.WithField("key", "value")

最佳答案

你可以调用 cl.WithFields()

package main

import "github.com/Sirupsen/logrus"

func main() {
    cl := logrus.WithFields(
        logrus.Fields{
            "extra_field_one": "extra_value_one",
        })
    cl = cl.WithFields(
        logrus.Fields{
            "extra_field_two": "extra_value_two",
        })
    cl.Info("hello world")
}

输出是:

INFO[0000] hello world extra_field_one="extra_value_one" extra_field_two="extra_value_two"

关于go - Logrus 向上下文记录器添加额外字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42920666/

相关文章:

Go chi 渲染难以处理绑定(bind)列表

go - 在 golang (gin) 中访问数组后参数

reflection - 使用反射检查分配给 interface{} 变量的函数签名

email - smtp.SendMail无法向多个recipent golang发送邮件

multithreading - GO:在简单的 tcp 服务器上超过 10000 个线程?

sockets - 使用套接字时重用读取缓冲区

go - WebSocket 与 GopherJS 的兼容性

go - 使用 HTTP GET 请求调用 tcp i/o 超时

go - 带有空格的POST参数

Golang 包不在 GOROOT (/usr/local/go/src/packageName)