您的位置:首页 > 其它

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

2017-08-16 16:22 357 查看
由于第一次使用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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐