首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Logrus向contextlogger添加额外字段

Logrus向contextlogger添加额外字段
EN

Stack Overflow用户
提问于 2017-03-21 07:23:20
回答 1查看 7.9K关注 0票数 7

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

代码语言:javascript
复制
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是可能的。还发现可以添加一个额外的字段:

代码语言:javascript
复制
cl = cl.WithField("key", "value")
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-03-21 08:12:00

你可以直接打电话给cl.WithFields()

代码语言:javascript
复制
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")
}

产出如下:

代码语言:javascript
复制
INFO[0000] hello world extra_field_one="extra_value_one" extra_field_two="extra_value_two"
票数 17
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42920666

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档