zoukankan      html  css  js  c++  java
  • Java日志设计&实践(2)

    设计阶段主要考虑几个问题

    1. 按应用或功能拆分日志,但要把握度,过犹不及
    2. 日志配置需支持动态调整

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

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

    <context-param>
    
      <param-name>log4jConfigLocation</param-name>
    
      <param-value>/WEB-INF/log4j.properties</param-value>
    
     </context-param>
    
    
     <context-param>
    
      <param-name>log4jRefreshInterval</param-name>
    
      <param-value>10000</param-value>
    
     </context-param>
    
    
     <listener>
    
      <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    
     </listener>

    【注意】

    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-8
    
    log4j.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同时加载同一个工程,可以分别指定日志输出目录吗?

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

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

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

  • 相关阅读:
    Redis 3.0.4 链表
    Redis 3.0.4 简单动态字符串(sds)
    4. 寻找两个有序数组的中位数
    redis主从同步异常
    redis重命名flushall和flushdb重启失败
    redis3.2 aof重写
    【转载】Redis 4.0 自动内存碎片整理(Active Defrag)源码分析
    [转]memcached对key和value的限制 memcached的key最大长度和Value最大长度
    LSM树(Log-Structured Merge Tree)存储引擎
    Linux使用详解(进阶篇)
  • 原文地址:https://www.cnblogs.com/xxt-mov/p/4226868.html
Copyright © 2011-2022 走看看