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
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值