log4cplus的配置文件使用及问题解决

由于第一次使用log4cplus,在使用过程中遇到了一些问题,现在记录一下。

1.log4cplus的日志输出可以通过代码创建布局规则,但由于此方法相较于配置文件不太灵活且不方便,所以采用配置文件方式。


2.输出日志类别预定:程序想输出正常运行日志和错误日志,且分开保存方便查阅。


3.日志名字以日期命名,一天一次。


4.实现:参考了网上的一些配置文件写法,自己也亲自试验过很多次,但是不知道是不是版本更新的缘故还是环境问题导致结果与预期不符。

参考代码:

# log4cplus.rootLogger=TRACE, ALL_MSGS
# log4cplus.appender.ALL_MSGS=log4cplus::DailyRollingFileAppender
# log4cplus.appender.ALL_MSGS.Schedule=DAILY
# log4cplus.appender.ALL_MSGS.DatePattern=yyyy-MM-dd
# log4cplus.appender.ALL_MSGS.File=log.log
# log4cplus.appender.ALL_MSGS.MaxFileSize=100MB
# log4cplus.appender.ALL_MSGS.MaxBackupIndex=1
# log4cplus.appender.ALL_MSGS.layout=log4cplus::PatternLayout
# log4cplus.appender.ALL_MSGS.layout.ConversionPattern=%d{%Y-%m-%d %H:%M:%S,%Q} %-4l [%t] %-5p %c{2} - %m%n
# log4cplus.appender.ALL_MSGS.filters.1=log4cplus::spi::LogLevelRangeFilter
# log4cplus.appender.ALL_MSGS.filters.1.LogLevelMin=TRACE
# log4cplus.appender.ALL_MSGS.filters.1.LogLevelMax=FATAL


5.问题:1)不能生成日志文件。2)修改log4cplus.appender.ALL_MSGS.File为全路径后可生成log.log文件,但是关闭程序后生成的自动命名文件却没有以日期命名。


6.解决:我的环境为win10(64)+vs2017+log4cplus1.21,问题1解决方法为必须指定全路径文件名。问题2解决办法为去掉 log4cplus.appender.ALL_MSGS.DatePattern条目,正是由于这个原因导致多次试验未能正常生产文件。


7.完整配置:

log4cplus.rootLogger=DEBUG,ALL_MSGS,ERROR_MSGS


log4cplus.appender.ALL_MSGS=log4cplus::DailyRollingFileAppender
log4cplus.appender.ALL_MSGS.Schedule=DAILY
#log4cplus.appender.ALL_MSGS.DatePattern=yyyy-MM-dd
log4cplus.appender.ALL_MSGS.MaxFileSize=100MB
log4cplus.appender.ALL_MSGS.MaxBackupIndex=10
log4cplus.appender.ALL_MSGS.CreateDirs=true
log4cplus.appender.ALL_MSGS.File=全路径\log\log.log
log4cplus.appender.ALL_MSGS.layout=log4cplus::PatternLayout
log4cplus.appender.ALL_MSGS.layout.ConversionPattern=%d{%Y-%m-%d %H:%M:%S,%Q} %-4l [%t] %-5p %c{2} - %m%n
#Range
log4cplus.appender.ALL_MSGS.filters.1=log4cplus::spi::LogLevelRangeFilter
log4cplus.appender.ALL_MSGS.filters.1.LogLevelMin=TRACE
log4cplus.appender.ALL_MSGS.filters.1.LogLevelMax=FATAL
log4cplus.appender.ALL_MSGS.filters.1.AcceptOnMatch=true
log4cplus.appender.ALL_MSGS.filters.2=log4cplus::spi::DenyAllFilter


log4cplus.appender.ERROR_MSGS=log4cplus::DailyRollingFileAppender
log4cplus.appender.ERROR_MSGS.Schedule=DAILY
#log4cplus.appender.ERROR_MSGS.DatePattern=yyyy-MM-dd
log4cplus.appender.ERROR_MSGS.MaxFileSize=100MB
log4cplus.appender.ERROR_MSGS.MaxBackupIndex=10
log4cplus.appender.ERROR_MSGS.CreateDirs=true
log4cplus.appender.ERROR_MSGS.File=全路径\log\error.log
log4cplus.appender.ERROR_MSGS.layout=log4cplus::PatternLayout
log4cplus.appender.ERROR_MSGS.layout.ConversionPattern=%d{%Y-%m-%d %H:%M:%S,%Q} %-4l [%t] %-5p %c{2} - %m%n
#Match 
log4cplus.appender.ERROR_MSGS.filters.1=log4cplus::spi::LogLevelMatchFilter
log4cplus.appender.ERROR_MSGS.filters.1.LogLevelToMatch=ERROR
log4cplus.appender.ERROR_MSGS.filters.1.AcceptOnMatch=true
log4cplus.appender.ERROR_MSGS.filters.2=log4cplus::spi::DenyAllFilter

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
log4cplus 是一个开源的日志库,用于 C++ 程序的日志记录。要配置 log4cplus,你可以按照以下步骤进行操作: 1. 引入 log4cplus 库:首先,确保已经将 log4cplus 库添加到你的项目中。你可以从 log4cplus 的官方网站(http://log4cplus.sourceforge.net/)下载最新版本的库,并将其链接到你的项目中。 2. 创建配置文件:在你的项目中创建一个配置文件,通常以 ".properties" 或 ".conf" 为后缀名。配置文件用于指定日志输出的格式、输出目标等参数。下面是一个简单的示例配置文件: ``` # 设置根日志记录器的输出级别为DEBUG log4cplus.rootLogger=DEBUG, STDOUT # 定义输出目标为控制台 log4cplus.appender.STDOUT=log4cplus::ConsoleAppender # 设置控制台输出格式 log4cplus.appender.STDOUT.layout=log4cplus::PatternLayout log4cplus.appender.STDOUT.layout.ConversionPattern=[%D{%Y-%m-%d %H:%M:%S}] [%t] [%p] %m%n ``` 3. 加载配置文件:在你的代码中加载配置文件,并初始化 log4cplus。通常在程序的入口处进行加载和初始化。下面是一个示例代码片段: ```cpp #include <log4cplus/logger.h> #include <log4cplus/configurator.h> int main() { // 加载配置文件 log4cplus::PropertyConfigurator::doConfigure("log4cplus.properties"); // 获取日志记录器 log4cplus::Logger logger = log4cplus::Logger::getRoot(); // 使用日志记录器输出日志 LOG4CPLUS_DEBUG(logger, "This is a debug message."); return 0; } ``` 以上是一个简单的 log4cplus 配置使用示例。你可以根据你的需求进一步调整和扩展配置文件,以满足你的日志记录需求。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值