java 日志设计_Java日志设计&实践(2) - 设计篇

设计阶段主要考虑几个问题 按应用或功能拆分日志,但要把握度,过犹不及

日志配置需支持动态调整

使用Spring的Log4jConfigListener,实现动态调整日志级别

web.xml对应位置加入如下内容

log4jConfigLocation

/WEB-INF/log4j.properties

log4jRefreshInterval

10000

org.springframework.web.util.Log4jConfigListener

【注意】

1.不要把log4jConfigLocation指定为/WEB-INF/classes/log4j.properties

当log4jConfigLocation指定为/WEB-INF/classes/log4j.properties,如果需要动态调整日志配置,可能会引起类的重新加载。但动态调整/WEB-INF/log4j.properties不会引起类的重新加载

2.log4jRefreshInterval的单位是毫秒

3./WEB-INF/log4j.properties和/WEB-INF/classes/log4j.properties不能同时存在,否则会报异常

4.JUnit单元测试类的问题

运行单元测试时,报以下错误

log4j:WARN No appenders could be found for logger (org.springframework.context.support.ClassPathXmlApplicationContext).

log4j:WARN Please initialize the log4j system properly.

log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

原因是找不到默认的log4j配置文件,可以手动指定,如:

Log4jConfigurer.initLogging("classpath:log4j.test.properties");

log4j.test.properties是专门为执行单元测试类使用的一个配置文件

为每个工程指定一个独立的日志文件

/WEB-INF/log4j.properties配置如下

log4j.rootLogger=info, file

log4j.appender.file=org.apache.log4j.DailyRollingFileAppender

log4j.appender.file.File=${catalina.home}/logs/projectName

log4j.appender.file.DatePattern='.'yyyy-MM-dd'.log'log4j.appender.file.Encoding=UTF-8log4j.appender.file.layout=org.apache.log4j.PatternLayout

log4j.appender.file.layout.ConversionPattern=%p %d %m [%l] %n

log4j.appender.file.File=${catalina.home}/logs/projectName

中的projectName可以是工程名等唯一标识一个工程的字符串

${catalina.home}表示当前tomcat工程根目录,Tomcat启动时设置该变量

通过以上配置,就可以达到为每个工程指定一个独立的日志文件的目录

小结

现在来解答如下几个问题

【问】一个Tomcat加载多个工程,如何确定日志中的内容是哪个工程的?

【答】为每个工程指定独立的日志文件,避免多个工程日志文件输出到一个文件的问题

【问】多个Tomcat同时加载同一个工程,可以使用log4j的DailyRollingFileAppender等文件类Appender吗?

【答】可以,指定文件名时,可以使用类似

log4j.appender.file.File=${catalina.home}/logs/projectName

的配置,这样每个Tomcat的日志分别保存

【问】多个Tomcat同时加载同一个工程,可以分别指定日志输出目录吗?

【答】可以 同上一个问题的答案

【问】可以动态调整一个类的日志级别吗?

【答】可以 本文已经提供了一种思路

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值