15

我使用 SLF4j 作为我的日志框架,由 log4j 支持。我的问题是我正在寻找一种方法来在运行时更改我的记录器的日志记录级别。

我知道 slf4j 不允许直接通过其自己的 API 进行此操作,因此,我必须直接访问日志记录提供程序。就个人而言,我发现这是 slf4j 的一个巨大缺陷。所以现在我的问题是如何通过 slf4j 以编程方式确定我正在使用哪个提供程序?使用 slf4j 的最大目的是让您成为提供者不可知论者——您可以轻松地在您最喜欢的日志系统之间切换,而无需重新编码任何东西。但是现在,如果我必须直接调用 log4j,我就失去了这种能力。

至少,我希望能够确定我是否使用 log4j 作为提供者,如果是,则允许用户切换日志级别。

如果我这样做 LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME),结果是一个实例,org.slf4j.impl.Log4jLoggerAdapter甚至不是org.apache.log4j.Logger(正如我所希望/预期的那样)。

有什么办法可以找出来吗?

谢谢,埃里克

4

1 回答 1

13

SLF4J 被设计为的抽象,而不是应用程序(当然,为了保持一致性,您可以并且仍然应该在自己的应用程序的日志记录调用中使用 SLF4J)。在您自己的应用程序中,您选择底层记录器框架,因此可以在 logging-config-specific 部分访问 log4j API。

恕我直言,图书馆不应该因为更改日志配置而胡闹,因此它不适合在 SLF4J API 上使用。

于 2012-06-21T19:17:57.710 回答