log4j-slf4j-impl / log4j v2 - setting custom log4j.xml destination(log4j-slf4j-impl/log4j v2-设置自定义log4j.xml目标)
问题描述
在我的应用程序运行时,我希望动态指定log4j配置文件的位置。
这是因为它不是捆绑在JAR中的资源,而是磁盘上的实际文件,如果提高日志记录级别有问题,可以对其进行编辑。
使用log4j v1.2时,可以使用DOMConfigurator.configure(URL)执行此操作。
但现在我已升级到log4j-slf4j-impl/log4j v2,此方法已不复存在。
我可以看到如何直接配置log4j,但是我希望使用现有的slf4j兼容的XML文件,而不必更改它。
有人能帮忙吗?
推荐答案
Log4j2.x使用ConfigurationFactory
解析配置文件。每种格式都有一个工厂和一个默认工厂。默认工厂尝试从文件扩展名猜测正确的格式:遗憾的是,旧的Log4j 1.2和新的Log4j 2.x格式都有.xml
扩展名,因此需要额外的配置。
为了解析Log4j 1.2 XML格式,您需要添加log4j-1.2.api
项目并替换默认工厂:
import org.apache.log4j.xml.XmlConfigurationFactory;
import org.apache.logging.log4j.core.config.ConfigurationFactory;
ConfigurationFactory.setConfigurationFactory(new XmlConfigurationFactory());
在此之后设置一个简单的:
Configurator.reconfigure(new URI("URI of your file"));
将您的配置应用到相应的LoggerContext
。
这篇关于log4j-slf4j-impl/log4j v2-设置自定义log4j.xml目标的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:log4j-slf4j-impl/log4j v2-设置自定义log4j.xml目标
基础教程推荐
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01
- 在螺旋中写一个字符串 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01