log4j-slf4j-impl / log4j v2 - 设置自定义 log4j.xml 目的地
log4j-slf4j-impl / log4j v2 - setting custom log4j.xml destination
在我的应用程序运行时,我想动态指定 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
。
在我的应用程序运行时,我想动态指定 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
。