由于第一次使用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