Log4j使用手册

pom.xm中依赖的jar包

<dependency>
	<groupId>log4j</groupId>
	<artifactId>log4j</artifactId>
	<version>1.2.16</version>
</dependency>

log4j日志等级

log4j根配置语法:

log4j.rootLogger=[level], appenderName,appenderName…

level:日志等级;
appenderName:日志输出位置;
Log4j根据日志信息的重要程度,分OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL;
官方建议使用四个级别,优先级从高到低分别是 ERROR、WARN、INFO、DEBUG;
假如rootLogger定义的是DEBUG 那所有的报错信息都会输出;

log4j.rootLogger=DEBUG,Console,File,DailyRollingFile,RollingFile,DFile,EFILE

#Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender  
log4j.appender.Console.layout=org.apache.log4j.PatternLayout  
log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n

#File
log4j.appender.File = org.apache.log4j.FileAppender
log4j.appender.File.File =E://xmlData/log/thread_demo/log2.log
log4j.appender.File.layout = org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
log4j.appender.FIEL.Append = false

#DailyRollingFile
log4j.appender.DailyRollingFile = org.apache.log4j.DailyRollingFileAppender
log4j.appender.DailyRollingFile.File = E://xmlData/log/thread_demo/log3.log
log4j.appender.DailyRollingFile.layout = org.apache.log4j.PatternLayout
log4j.appender.DailyRollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n

#RollingFile
log4j.appender.RollingFile = org.apache.log4j.RollingFileAppender
log4j.appender.RollingFile.File = E://xmlData/log/thread_demo/log4.log
log4j.appender.RollingFile.MaxFileSize=1KB
log4j.appender.RollingFile.MaxBackupIndex=3
log4j.appender.RollingFile.layout = org.apache.log4j.PatternLayout
log4j.appender.RollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
import org.apache.log4j.Logger;

public class Test {
    static Logger logger = Logger.getLogger(Test.class);
    public static void main(String[] args) {
        logger.info("普通信息");
        logger.debug("调试debug信息");
        logger.error("报错error信息");
        logger.warn("告警warn信息");
        //int num=5;
        //System.out.println(num%2);
    }
}

log4j输出类型配置

(1)org.apache.log4j.ConsoleAppender(控制台);

(2)org.apache.log4j.FileAppender(文件);

(3)org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件) ;

(4)org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件);

(5)org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方);

一般使用(1)、(3)、(4)
org.apache.log4j.RollingFileAppender配置中参数解释:
MaxFileSize 是日志文件的最大尺寸;
MaxBackupIndex是日志文件的个数,如若超过,则覆盖,主要考虑到的是硬盘的容量问题;

log4j layout日志信息格式

(1)org.apache.log4j.HTMLLayout(以HTML表格形式布局);

(2)org.apache.log4j.PatternLayout(可以灵活地指定布局模式);

(3)org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串);

(4)org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息);

一般使用org.apache.log4j.PatternLayout
PatternLayout中ConversionPattern属性,可以灵活配置输出属性
%m 输出代码中指定的消息;

%M 输出打印该条日志的方法名;

%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL;

%r 输出自应用启动到输出该log信息耗费的毫秒数;

%c 输出所属的类目,通常就是所在类的全名;

%t 输出产生该日志事件的线程名;

%n 输出一个回车换行符,Windows平台为"rn”,Unix平台为"n”;

%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd HH:mm:ss,SSS},输出类似:2002-10-18 22:10:28,921;

%l 输出日志事件的发生位置,及在代码中的行数;

示例中%-5p :最多5个占位符的情况下,不足的数据用空格占用,是为了使日志格式对齐;
在这里插入图片描述

Log4j Threshold属性指定输出等级

当需要将一些报错的日志单独存放,需要使用Threshold属性
Threshold可以指定日志的level
注意:Threshold的日志等级必须小于等于log4j.rootLogger的日志等级
log4j.Append:指定是否追加日志内容,不追加的情况下,会覆盖日志内容,默认为true;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值