Logrus 记录器指向特定日志级别的指针

问题描述

我使用的是 MQTT paho 库,它有自己的记录器接口,由 logrus 记录器实现,paho 库有多个级别:ERROR、CRITICAL 等。 我试图做这样的事情:

    MQTT.ERROR = app.Log.WithField("level","ERROR")
    MQTT.CRITICAL = app.Log.WithField("level","CRITICAL")

但是这不会记录,因为你不能有一个名为 level 的字段,如果你不添加 level,它总是进入 info 级别,因为 entry.Print 是在里面执行 log.Info 的实现,有没有办法将指针传递给具有相应日志级别的 logrus 记录器,而不对其进行新的包装。

我知道这可以通过新的包来完成,该包将实现 mqtt.Logger,其中包含内部具有 log.Error 调用函数。但我觉得应该有更好的方法来做到这一点。

解决方法

我知道可以使用将实现的新包来完成 mqtt.Logger 带有内部将调用 log.Error 的函数。但 我觉得应该有更好的方法来做到这一点。

它不必在新包中,您只需定义一个结构体并使其在同一个包中实现 mqtt.Logger

恐怕没有更好的办法了

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...