2

我在我的项目中使用 log4cplus 进行日志记录。我创建了 logger.conf,我将在我的应用程序的开头加载它。

这是我的 logger.conf:

log4cplus.appender.Developer=log4cplus::RollingFileAppender
log4cplus.appender.Developer.DatePattern = ".yyyy-MM-dd"
log4cplus.appender.Developer.Schedule = HOURLY
log4cplus.appender.Developer.File=log/developer.log
log4cplus.appender.Developer.MaxFileSize=3MB
log4cplus.appender.Developer.MaxBackupIndex=10
log4cplus.appender.Developer.layout=log4cplus::PatternLayout
log4cplus.appender.Developer.layout.ContextPrinting=enabled
log4cplus.appender.Developer.layout.ConversionPattern=%D{%Y-%m-%d %H:%M:%S,%Q} [%t] %p - %m%n 
log4cplus.appender.Developer.Threshold=TRACE
log4cplus.logger.DEVELOPER=TRACE, Developer

我将在我的代码中加载我的配置文件,如下所示:

QString log_path = qApp->applicationDirPath() + "/log";
QDir().mkpath(log_path);
PropertyConfigurator logger(L"configs/logger.conf", Logger::getDefaultHierarchy());
logger.configure();

如您所见,每当我的日志达到 3MB 时,Log4Cplus 都会进行备份(developer.log.1 到 developer.log.10)。

我如何告诉 Log4Cplus 压缩它创建的备份(在我的配置文件中)?

4

1 回答 1

1

我不确定,但我认为您不能在配置文件中指定它。一种方法是创建自己的附加程序,从 RollingFileAppender 继承,然后在复制后添加压缩步骤。

于 2013-11-20T10:30:57.260 回答