java - log4j-slf4j-impl/log4j v2 - 设置自定义 log4j.xml 目标

标签 java log4j slf4j

在我的应用程序运行时,我想动态指定 log4j 配置文件的位置。

这样一来,它不是捆绑在 JAR 中的资源,而是磁盘上的实际文件,如果存在增加日志记录级别的问题,可以对其进行编辑。

使用 log4j v1.2 时,可以使用 DOMConfigurator.configure(URL) 来执行此操作。

但是现在我已经升级到log4j-slf4j-impl/log4j v2,这个方法不再存在了。

我可以看到如何直接配置 log4j,但我想使用现有的 slf4j 兼容 XML 文件,而无需更改它。

有人可以帮忙吗?

最佳答案

Log4j 2.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

关于java - log4j-slf4j-impl/log4j v2 - 设置自定义 log4j.xml 目标,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70352815/

相关文章:

java - log4j:文件已创建但未写入

java - 如何使 ibatis 记录完整的 SQL 语句,而不仅仅是用 '?' 替换参数

java - Lombok SLF4J impl 继承问题

java - SL4J 配置更改或正则表达式以屏蔽 Json 中的电子邮件(由 '@' 和 '.com' 识别)

java - ARM 上 Java 8u6 的内存丢失 (BeagleBoneBllack)

java - 两个浮点值相除得到零

java - 使用@ManagedProperty 在托管bean 之间调用方法

java - 使用正则表达式从使用 xeger java 库生成的字符串中解析 id

java - 如何从 log4j.xml 的 .properties 文件中获取动态值

java - 智能 : Is there an Intention Action to convert old style Log4J calls to new style SLF4J calls?