我使用SLF4j作为我的日志框架,由log4j支持.我的问题是我正在寻找一种方法来在运行时更改记录器的日志记录级别.
我知道slf4j不允许直接通过自己的API,因此,我必须直接访问日志记录提供程序.就个人而言,我发现这是slf4j的一个巨大缺陷.所以现在我的问题是如何通过slf4j以编程方式确定我正在使用哪个提供程序?使用slf4j的最大目的是让您成为提供者不可知的 - 您可以轻松地在您喜欢的日志记录系统之间切换,而无需重新编码.但是现在,如果我必须直接调用log4j,我就失去了这种能力.
至少,我希望能够确定我是否使用log4j作为提供程序,如果是,则允许用户切换日志级别.
如果我这样做 LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME),结果是一个实例org.slf4j.impl.Log4jLoggerAdapter而不是偶数org.apache.log4j.Logger(正如我希望/期望的那样).
有没有办法找到这个?
谢谢,埃里克
art*_*tol 13
SLF4J被设计为库的抽象,而不是应用程序(当然,您可以并且仍然应该在您自己的应用程序的日志记录调用中使用SLF4J,以保持一致性).在您自己的应用程序中,您选择了底层记录器框架,因此可以在特定于logging-config的部分中访问log4j API.
没有办法让图书馆改变日志配置,恕我直言,所以它不适合在SLF4J API上.
| 归档时间: |
|
| 查看次数: |
6120 次 |
| 最近记录: |