Ich habe ein Problem mit dem Projekt logback. Meine Anforderung ist, dass ich Log-Eigenschaften dynamisch erstellen muss. Lassen Sie mich dies anhand eines Beispiels erklären.
Mein Projekt erstellt eine Socket-Kommunikation mit einem externen System und es kann mehrere Sockets haben. Für jeden Socket möchte ich verschiedene Protokolldateien haben, die die gelesenen und gesendeten Nachrichten enthalten. Um dies zu erreichen, erstelle ich die Logger für Sockets programmatisch. Das Problem ist, dass die Logger, die ich erstellt habe, unbrauchbar werden, wenn ich sie auf der Grundlage von logback.xml neu konfigurieren möchte (indem ich scan="true" hinzufüge oder den Logback neu initialisiere). Wie kann ich das beheben oder können Sie mir eine andere Lösung empfehlen?
Dies ist meine Konfigurationsdatei (logback.xml)
<?xml version="1.0" ?>
<configuration>
<property name="HOME_PATH" value="/data/logs/myapp/" scope="CONTEXT" />
<property name="MYAPP_LOG_FILE" value="myapp.log" />
<property name="MYAPP_ROLLING_TEMPLATE" value="%d{yy-MM-dd}" scope="CONTEXT" />
<property name="MYAPP_OLD_LOG_FILE" value="${MYAPP_LOG_FILE}.%d{yy-MM-dd}" />
<property name="DEFAULT_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%file:%line] [%level] %msg%n" scope="CONTEXT" />
<appender name="myAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${HOME_PATH}${MYAPP_LOG_FILE}</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${HOME_PATH}${MYAPP_LOG_FILE}.${MYAPP_ROLLING_TEMPLATE}</fileNamePattern>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>${DEFAULT_PATTERN}</pattern>
</encoder>
</appender>
<logger name="com.myapp" level="DEBUG" additivity="false">
<appender-ref ref="myAppender" />
</logger>
<root level="OFF">
</root>
</configuration>
und hier können Sie sehen, wie ich Logger programmatisch erstelle (auch hier gilt, dass ich dies nur für Socket-Logs mache).
public static Logger createLogger(String name) {
ch.qos.logback.classic.Logger templateLogger = (ch.qos.logback.classic.Logger) LogUtil.getLogger("com.myapp");
LoggerContext context = templateLogger.getLoggerContext();
String logDir = context.getProperty("HOME_PATH");
PatternLayoutEncoder encoder = new PatternLayoutEncoder();
encoder.setPattern(context.getProperty("DEFAULT_PATTERN"));
encoder.setContext(context);
DefaultTimeBasedFileNamingAndTriggeringPolicy<ILoggingEvent> timeBasedTriggeringPolicy = new DefaultTimeBasedFileNamingAndTriggeringPolicy<ILoggingEvent>();
timeBasedTriggeringPolicy.setContext(context);
TimeBasedRollingPolicy<ILoggingEvent> timeBasedRollingPolicy = new TimeBasedRollingPolicy<ILoggingEvent>();
timeBasedRollingPolicy.setContext(context);
timeBasedRollingPolicy.setFileNamePattern(logDir + name + ".log." + context.getProperty("MYAPP_ROLLING_TEMPLATE"));
timeBasedRollingPolicy.setTimeBasedFileNamingAndTriggeringPolicy(timeBasedTriggeringPolicy);
timeBasedTriggeringPolicy.setTimeBasedRollingPolicy(timeBasedRollingPolicy);
RollingFileAppender<ILoggingEvent> rollingFileAppender = new RollingFileAppender<ILoggingEvent>();
rollingFileAppender.setAppend(true);
rollingFileAppender.setContext(context);
rollingFileAppender.setEncoder(encoder);
rollingFileAppender.setFile(logDir + name + ".log");
rollingFileAppender.setName(name + "Appender");
rollingFileAppender.setPrudent(false);
rollingFileAppender.setRollingPolicy(timeBasedRollingPolicy);
rollingFileAppender.setTriggeringPolicy(timeBasedTriggeringPolicy);
timeBasedRollingPolicy.setParent(rollingFileAppender);
encoder.start();
timeBasedRollingPolicy.start();
rollingFileAppender.stop();
rollingFileAppender.start();
ch.qos.logback.classic.Logger logbackLogger = (ch.qos.logback.classic.Logger) LogUtil.getLogger(name);
logbackLogger.setLevel(templateLogger.getLevel());
logbackLogger.setAdditive(false);
logbackLogger.addAppender(rollingFileAppender);
return logbackLogger;
}
Und so reinitialisiere ich logback
private static void initializeLogback() {
File logbackFile = new File(logFilePath);
System.setProperty("logback.configurationFile", logbackFile.getAbsolutePath());
StaticLoggerBinder loggerBinder = StaticLoggerBinder.getSingleton();
LoggerContext loggerContext = (LoggerContext) loggerBinder.getLoggerFactory();
loggerContext.reset();
JoranConfigurator configurator = new JoranConfigurator();
configurator.setContext(loggerContext);
try {
configurator.doConfigure(logbackFile);
} catch( JoranException e ) {
throw new ColumbusRuntimeException(e.getMessage(), e);
}
}