Log4Qt创建每日滚动日志

栏目: 编程工具 · 发布时间: 7年前

内容简介:Log4Qt创建每日滚动日志

Log4Qt创建每日滚动日志

1.代码如下:

QString path=FIX_DIR+QDate::currentDate().toString("yyyyMMdd");
FileUtility::mkpath(path);      //创建目录
log = Log4Qt::Logger::rootLogger();
//控制日志文本格式
PatternLayout *lay=new PatternLayout(PatternLayout::TTCC_CONVERSION_PATTERN);
lay->setConversionPattern("%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n");
lay->activateOptions();
//控制日志输出方式,控制台、文件、日滚动等
Log4Qt::DailyRollingFileAppender* app= new Log4Qt::DailyRollingFileAppender(lay,path+"/yjb","yyyy-MM-dd-hh-mm'.log'");
app->setAppendFile(true);
app->activateOptions();
log->addAppender(app);
log->>debug("first log");

2.生成的文件内容如下:

2017-02-13 20:39:43 [root]-[DEBUG] first log

3.注意事项

  1. PatternLayout、DailyRollingFileAppender生命周期应该与logger生命周期相同。所以尽量用new来创建堆中实例,或者用成员变量。

  2. 当天生成的日志文件名无后缀仅包含原始名字,等第二天软件运行时会自动将日志文件按设定格式进行重命名。本文此处设置的是每分钟一个日志文件。粒度控制由 “Log4Qt::DailyRollingFileAppender* app= new Log4Qt::DailyRollingFileAppender(lay,path+”/yjb”,”yyyy-MM-dd-hh-mm’.log’”);”执行。将其改为”Log4Qt::DailyRollingFileAppender* app= new Log4Qt::DailyRollingFileAppender(lay,path+”/yjb”,”yyyy-MM-dd’.log’”);”即为每日滚动一个日志文件。

  3. 一个logger可以添加多个Appender,即可实现同一条信息写入多个输出“文件”中。

  4. Log4Qt可以将所有qDebug()、qFatal()等输出到控制台的调试信息写入到日志文件中,通过如下语句调用即可

    Log4Qt::LogManager::setHandleQtMessages()

log4qt.h中说明如下:

* - \ref Log4Qt::LogManager "LogManager"
*   - A QtMessage handler can be installed via
*     \ref Log4Qt::LogManager::setHandleQtMessages() "setHandleQtMessages()",
*     to redirect all messages created by calls to qDebug(), qWarning(),
*     qCritical() and qFatal() to a logger. The logger is named Qt and can be
*     accessed using \ref Log4Qt::LogManager::qtLogger() "qtLogger()".
*   - The initialisation procedure is available over a public method
*     (\ref Log4Qt::LogManager::startup() "startup()").
*   - The LogManager provides access to the logger used internally by the
*     package (\ref Log4Qt::LogManager::logLogger() "logLogger()") and to
*     its default initialisation procedure
*     (\ref Log4Qt::LogManager::configureLogLogger() "configureLogLogger()").
*

此处是quick dirty式的代码。未对各配置参数进行详细说明,也未对配置文件配置log4qt进行说明。:)

本文永久更新链接地址 http://www.linuxidc.com/Linux/2017-03/142017.htm


以上所述就是小编给大家介绍的《Log4Qt创建每日滚动日志》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web Security, Privacy and Commerce, 2nd Edition

Web Security, Privacy and Commerce, 2nd Edition

Simson Garfinkel / O'Reilly Media / 2002-01-15 / USD 44.95

Since the first edition of this classic reference was published, World Wide Web use has exploded and e-commerce has become a daily part of business and personal life. As Web use has grown, so have ......一起来看看 《Web Security, Privacy and Commerce, 2nd Edition》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码

html转js在线工具
html转js在线工具

html转js在线工具