gpt4 book ai didi

java - LOG4J2 - 如何以编程方式创建文件附加程序?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:29:18 25 4
gpt4 key购买 nike

我需要以编程方式设置文件附加程序。

我想在 log4j2.xml 上设置我的附加程序,但我想在运行时(以编程方式)仅写入这些附加程序之一。

<Configuration status="WARN">
<Appenders>
<File name="File_1" fileName="c:/FILE_1.log" >
<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
</File>
<File name="File_2" fileName="c:/FILE_2.log" >
<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
</File>
<File name="File_3" fileName="c:/FILE_3.log" >
<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
</File>
</Appenders>
<Loggers>
<Root level="debug">
<AppenderRef ref="File_1"/>
<AppenderRef ref="File_2"/>
<AppenderRef ref="File_3"/>
</Root>
</Loggers>

示例:

     if(condition.equals("A")){
//write log on File_1
}else if(condition.equals("B")){
//write log on File_2
}else {
//write log on File_3
}

查看 Internet 上的各种教程,他们解释了如何在运行时以编程方式添加附加程序;有没有办法选择在运行时只有 xml 配置文件中定义的附加程序之一?

第一个解决方案:

我已尝试通过以下方式解决问题,但我对我的解决方案并不满意,因为 log4j2.xml 中定义的文件未以编程方式删除,并且 第一个 Appender 从未删除! 我认为 log4j2 中存在错误:https://issues.apache.org/jira/browse/LOG4J2-135 (状态已解决,但我不这么认为...我正在使用 log4j-2.0-beta9)

static org.apache.logging.log4j.core.Logger coreLogger =    
(org.apache.logging.log4j.core.Logger)LogManager.getLogger(MyClass.class.getName());
static LoggerContext context = (LoggerContext)coreLogger.getContext();
static BaseConfiguration configuration = (BaseConfiguration)context.getConfiguration();

static String FILE_1 = "File_1";
static String FILE_2 = "File_2";
static String FILE_3 = "File_3";

private static Map<String, Boolean> appendersMap;
static
{
appendersMap = new HashMap<String, Boolean>();
appendersMap.put(FILE_1, true);
appendersMap.put(FILE_2, true);
appendersMap.put(FILE_3, true);
}

/**
* Configure appenders.
*
* @param appender the appender
*/
public static void configureAppenders(String appender){

if(appender.equals(FILE_1)){
addAppenders(FILE_1);
removeAppenders(FILE_2,FILE_3);
}

else if(appender.equals(FILE_3)){
addAppenders(FILE_3);
removeAppenders(FILE_1,FILE_2);
}

else if(appender.equals(FILE_2)){
addAppenders(FILE_2);
removeAppenders(FILE_1,FILE_3);
}

}

private static void addAppenders(String appender){
if (!appendersMap.get(appender)){
appendersMap.put(appender, true);
coreLogger.addAppender(configuration.getAppender(appender));
}
}

private static void removeAppenders(String... appenders){
for(String appender : appenders){
appendersMap.put(appender, false);
coreLogger.removeAppender(configuration.getAppender(appender));
}
}

最佳答案

问这个问题已经有一段时间了,并且有许多请求支持更好的 Log4j 2 编程配置。从 Log4j 2.4 开始,API 被添加到 log4j-core 以促进 programmatic configuration .

新的 ConfigurationBuilder API 允许用户构建组件定义。使用此 API,无需直接使用实际配置对象(如 LoggerConfig 和 FileAppender),这需要大量关于 Log4j 如何在后台工作的知识。组件定义被添加到 ConfigurationBuilder 中,一旦收集了所有定义,所有实际的配置对象(如 Loggers 和 Appenders)就会被构造。感觉有点像 XML 配置语法,只是你写的是 Java 代码。

请注意,新的 ConfigurationBuilder API 允许用户代码创建新的配置或完全替换现有配置。如果您的用例不同,并且您想在 Log4j 启​​动后以编程方式修改(而不是替换)现有配置,那么您将需要使用实际的配置对象。在这种情况下,请参阅 Programmatically Modifying the Current Configuration after Initialization手册的一部分。

如果您确实需要直接使用内部配置对象,请注意您需要调用LoggerContext.updateLoggers()Configurator.initialize (Configuration) 最后使您的更改生效。例如:

final LoggerContext ctx = (LoggerContext) LogManager.getContext(false);
final Configuration config = ctx.getConfiguration();
... // make changes
ctx.updateLoggers(); // NECESSARY!

关于java - LOG4J2 - 如何以编程方式创建文件附加程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20570049/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com