【问题标题】:How can I compress backup log files?如何压缩备份日志文件?
【发布时间】:2013-12-08 07:09:49
【问题描述】:

我在我的项目中使用 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

这就是我加载 logger.conf 的方式:

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

每当我想登录时,我都会使用以下行:

Logger::getInstance(L"DEVELOPER").log(INFO_LOG_LEVEL, L"..............");

我想知道两件事:

  1. 如何告诉 Log4Cplus 压缩备份日志?

    在一些帖子中我看到了这个回复:

    我需要创建自己的appender,继承自RollingFileAppender,然后添加压缩步骤。

    如果可能的话,谁能告诉我怎么做,好吗?我不知道如何实现。

  2. 如何为这些备份日志的名称添加模式?

    目前,Log4Cplus 使我的备份如下:

    developer.log.1
    developer.log.2
    developer.log.3
    ...
    

    我想添加日期和时间。

【问题讨论】:

    标签: c++ logging log4cplus


    【解决方案1】:

    您需要像这样实现自己的 Appender:

    class NewFileAppender : public ::log4cplus::RollingFileAppender
    {
    
    void 
    newFileAppender::rollover()
    {
        helpers::LogLog & loglog = getLogLog();
    
        // Close the current file
        out.close();
        out.clear(); // reset flags since the C++ standard specified that all the
                     // flags should remain unchanged on a close
    
        // If maxBackups <= 0, then there is no file renaming to be done.
        if (maxBackupIndex > 0)
        {
            rolloverCompressedFiles(filename, maxBackupIndex);
    
            // Rename fileName to fileName.DATE
            tstring target = filename + DATE;
    
            int ret;
    
            ret = file_rename (filename, target);
            //TODO: compress using zlib
        }
    }
    

    }

    【讨论】:

      猜你喜欢
      • 2013-12-04
      • 2015-08-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-06-04
      • 1970-01-01
      相关资源
      最近更新 更多