我在所有的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")发布于 2017-03-21 08:12:00
你可以直接打电话给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"https://stackoverflow.com/questions/42920666
复制相似问题