Eine Logdatei pro Lauf mit log4j

Wie konfiguriere ich log4j.properties so, dass es genau eine Protokolldatei pro Ausführung einer App gibt? Ich habe gelesen, dass Sie einen Zeitstempel im Dateinamen verwenden sollten, aber das wird im Laufe der Zeit viele Dateien pro Lauf erstellen.

Ich habe DailyRollingFileAppender und RollingFileAppender ausprobiert, kann aber nicht genau ein Protokoll pro Lauf konfigurieren. Das Protokoll sollte nicht in mehrere Protokolle aufgeteilt werden, und es sollte nicht abgeschnitten werden, und Dateien alter Läufe sollten erhalten bleiben.

Jede Klasse hat einen statischen org.slf4j.Logger für ihren eigenen Klassennamen:

private static final Logger log = LoggerFactory.getLogger(Foo.class);

Dies ist meine aktuelle log4j.properties

log4j.rootLogger=error, RootAppender, RootErrorAppender

#log4j.logger.com.example=info, qspaBackendAppender, stderr
log4j.logger.com.example=info, qspaBackendAppender
log4j.additivity.com.example=true

#log4j.logger.com.example.util=trace, qspaBackendAppender, stderr
#log4j.additivity.com.example.util=true

log4j.appender.qspaBackendAppender=org.apache.log4j.DailyRollingFileAppender
log4j.appender.qspaBackendAppender.file=logs/qspaBackend.log
log4j.appender.qspaBackendAppender.layout=org.apache.log4j.PatternLayout
log4j.appender.qspaBackendAppender.layout.ConversionPattern=<%d{yyyy-MM-dd HH:mm:ss}> %-5p : %C{1} %c{2} : %m%n

log4j.appender.stderr=org.apache.log4j.ConsoleAppender
log4j.appender.stderr.Target=System.err
log4j.appender.stderr.layout=org.apache.log4j.PatternLayout
log4j.appender.stderr.layout.ConversionPattern=%-5p %c{1}:%L - %m%n

log4j.appender.RootAppender=org.apache.log4j.RollingFileAppender
log4j.appender.RootAppender.file=logs/root.log
log4j.appender.RootAppender.layout=org.apache.log4j.PatternLayout
log4j.appender.RootAppender.layout.ConversionPattern=<%d{yyyy-MM-dd HH:mm:ss}> %-5p : %C{1} %c{2} : %m%n

log4j.appender.RootErrorAppender=org.apache.log4j.RollingFileAppender
log4j.appender.RootErrorAppender.file=logs/rootError.log
log4j.appender.RootErrorAppender.layout=org.apache.log4j.PatternLayout
log4j.appender.RootErrorAppender.layout.ConversionPattern=<%d{yyyy-MM-dd HH:mm:ss}> %-5p : %C{1} %c{2} : %m%n
log4j.appender.RootErrorAppender.threshold=error

Antworten auf die Frage(3)

Ihre Antwort auf die Frage