我使用了带有TimeBasedRollingPolicy的RollingFileAppender,因此在午夜创建一个新的日志文件,并保留10天的旧日志。 在午夜创建一个新的日志文件,但旧的日志文件将被立即删除,有时甚至会在几分钟后删除。
public static void init(String logfilename,String loggername,String pattern) throws Exception {
LoggerContext context = (LoggerContext)LoggerFactory.getILoggerFactory();
logfilename = new File(logfilename).getCanonicalPath();
PatternLayoutEncoder encoder = new PatternLayoutEncoder();
encoder.setContext(context);
encoder.setPattern(pattern);
encoder.start();
RollingFileAppender<ILoggingEvent> rollingFileAppender = new RollingFileAppender<>();
rollingFileAppender.setContext(context);
rollingFileAppender.setName(loggername);
rollingFileAppender.setEncoder(encoder);
rollingFileAppender.setAppend(true);
rollingFileAppender.setFile(logfilename+".log");
TimeBasedRollingPolicy<ILoggingEvent> rollingPolicy = new TimeBasedRollingPolicy<>();
rollingPolicy.setContext(context);
rollingPolicy.setParent(rollingFileAppender);
rollingPolicy.setFileNamePattern(logfilename+".%d{yyyy-MM-dd}.log");
rollingPolicy.setMaxHistory(10);
rollingPolicy.setTotalSizeCap(FileSize.valueOf("100MB"));
rollingPolicy.setCleanHistoryOnStart(false);
rollingPolicy.start();
rollingFileAppender.setRollingPolicy(rollingPolicy);
rollingFileAppender.start();
Logger logger = (Logger)LoggerFactory.getLogger(loggername);
logger.setAdditive(false);
logger.setLevel(Level.INFO);
logger.detachAndStopAllAppenders();
logger.addAppender(rollingFileAppender);
}
我认为在这种情况下,MaxHistory应该意味着10天,但它不起作用。
答案 0 :(得分:0)
我已根据您的代码创建了一个最小的运行演示:
https://github.com/riskop/slf4j_logback_rollingfileappender_programatically
我刚刚将totalSizeCap降低到1KB,将fileNamePattern更改为每分钟滚动并创建了一个主要方法来驱动配置:
public static void main(String[] args) throws Exception {
init2("A_LOG_FILE", "A_LOGGER_NAME", "%d{HH:mm:ss.SSS} %-5level %logger - %msg%n");
while (true) {
org.slf4j.Logger logger = LoggerFactory.getLogger("A_LOGGER_NAME");
logger.warn("a warning " + System.currentTimeMillis());
Thread.sleep(1000);
}
}
public static void init2(String logfilename,String loggername,String pattern) throws Exception {
LoggerContext context = (LoggerContext)LoggerFactory.getILoggerFactory();
logfilename = new File(logfilename).getCanonicalPath();
PatternLayoutEncoder encoder = new PatternLayoutEncoder();
encoder.setContext(context);
encoder.setPattern(pattern);
encoder.start();
RollingFileAppender<ILoggingEvent> rollingFileAppender = new RollingFileAppender<>();
rollingFileAppender.setContext(context);
rollingFileAppender.setName(loggername);
rollingFileAppender.setEncoder(encoder);
rollingFileAppender.setAppend(true);
rollingFileAppender.setFile(logfilename+".log");
TimeBasedRollingPolicy<ILoggingEvent> rollingPolicy = new TimeBasedRollingPolicy<>();
rollingPolicy.setContext(context);
rollingPolicy.setParent(rollingFileAppender);
rollingPolicy.setFileNamePattern(logfilename+".%d{yyyy-MM-dd_HH-mm}.log");
rollingPolicy.setMaxHistory(10);
rollingPolicy.setTotalSizeCap(FileSize.valueOf("1KB"));
rollingPolicy.setCleanHistoryOnStart(false);
rollingPolicy.start();
rollingFileAppender.setRollingPolicy(rollingPolicy);
rollingFileAppender.start();
Logger logger = (Logger)LoggerFactory.getLogger(loggername);
logger.setAdditive(false);
logger.setLevel(Level.INFO);
logger.detachAndStopAllAppenders();
logger.addAppender(rollingFileAppender);
}
然而,它工作正常。根据非常低的capSize,上面的代码会产生一个或最多2个文件。如果我将capSize提高到10KB,则会产生3-4个文件。
所以我猜你的问题是由你的环境造成的。
你可以试试上面的代码吗?
您是否可以尝试在您的环境(文件系统,目录)中运行它。
如果我是你,我也会尝试关闭maxHistory,totalCapSize和cleanHistory设置。
答案 1 :(得分:0)
我找到了原因。这是我的错。我有一个旧的进程,它每小时清理一次目录。 :)。禁用后,logback按预期工作。您可以使用上面的代码作为示例。它工作正常。