log4j日志输出配置

Posted wyf-love-dch

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了log4j日志输出配置相关的知识,希望对你有一定的参考价值。

1.log4j的文件配置:

log4j.rootLogger = debug,stdout,I,E
#### 控制台打印 stdout:标准输出###
#log4j.appender.stdout = org.apache.log4j.ConsoleAppender
#log4j.appender.stdout.Target = System.out
#log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
#log4j.appender.stdout.layout.ConversionPattern = [%-5p] %dyyyy-MM-dd HH:mm:ss,SSS method:%l%n%m%n


#### 输出到文件file info ###
log4j.logger.info=I
#log4j.appender.I = org.apache.log4j.DailyRollingFileAppender
log4j.appender.I =com.shopping.test.LogAppender
log4j.appender.I.append = true
log4j.appender.I.Threshold = INFO
log4j.appender.I.datePattern = ‘.‘yyyy-MM-dd‘.log‘
log4j.appender.I.MaxFileSize=100000KB
log4j.appender.I.layout = org.apache.log4j.PatternLayout
log4j.appender.I.File = $catalina.home/logs_dk/info.log
log4j.appender.I.layout.ConversionPattern = [%-5p]_%dyyyy-MM-dd HH:mm:ss %c - %m%n
log4j.appender.I.encoding=UTF-8



### 记录error 级别的日志###
log4j.logger.error=E
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.datePattern = ‘.‘yyyy-MM-dd‘.log‘
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
#log4j.appender.E.File =/home/logs/error.log
#log4j.appender.E.File =F:\\logs\\dk\\error.log
log4j.appender.E.File = $catalina.home/logs_dk/error.log
log4j.appender.E.layout.ConversionPattern = %-dyyyy-MM-dd HH:mm:ss [ %t:%r ] - [ %p ] %m%n

2. 重写一个方法类制定自己的输出

package com.shopping.test;

import org.apache.log4j.DailyRollingFileAppender;
import org.apache.log4j.Priority;

public class LogAppender extends DailyRollingFileAppender 
    @Override
    public boolean isAsSevereAsThreshold(Priority priority) 
        // 只判断是否相等,不判断优先级
        return this.getThreshold().equals(priority);
    

我重写这个方法是在info 文件输出时候,过滤输出非Info级别的日志

 

3.在项目中:

 private static Logger logger = Logger.getLogger(FcodeViewAction.class);

  //logger.info("今日管理");
  //logger.error("今日管理出错");

这样就可以在自己定义的输出位置找要输出的日志文件了

以上是关于log4j日志输出配置的主要内容,如果未能解决你的问题,请参考以下文章

控制台输出日志混乱,log4j配置输出格式无效,怎么设置啊?

log4j怎样控制只输出自己写的代码的日志,不输出框架中的日志

Log4J日志配置详解和自定义log4j日志级别及输出日志到不同文件实现方法

log4j配置问题,每天生成一个日志文件

怎么通过log4j文件控制jar包里面的日志输出

log4j将不同的日志级别输出到tomcat下