log4j

log4j的使用步骤:

​ 1、建立一个maven工程,在pom.xml文件中加入下面的依赖

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

​ 2、加入log4j.properties配置文件,在配置文件中加入相关配置,具体信息在最后面

​ 3、在需要打印日志的类中加入下面的代码:

package com.lptxyl.log4j;

import org.apache.log4j.Logger;

public class Main {

	//加入下面这句话,然后调用打印的方法即可
	private static Logger logger = Logger.getLogger(Main.class);
	
	public static void main(String[] args) {
		logger.info("hello");
	}
	
}

log4j的properties文件(log4j.properties)配置常用的属性如下:

log4j.properties:

log4j.rootLogger=DEBUG, Console ,DFile ,EFILE

#Console

log4j.appender.Console=org.apache.log4j.ConsoleAppender

log4j.appender.Console.layout=org.apache.log4j.TTCCLayout

#DEBUGFile

log4j.appender.DFile = org.apache.log4j.FileAppender

log4j.appender.DFile.File = C://DEBUG.log

log4j.appender.DFile.layout = org.apache.log4j.PatternLayout

log4j.appender.DFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n #%-5p表示日志级别占5个字符

log4j.appender.DFile.Threshold = DEBUG

#ERRORFile

log4j.appender.EFILE = org.apache.log4j.FileAppender

log4j.appender.EFILE.File = C://ERROR.log

log4j.appender.EFILE.layout = org.apache.log4j.PatternLayout

log4j.appender.EFILE.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n

log4j.appender.EFILE.Threshold = ERROR

其中每个属性的意思如下:

log4j.rootLogger=[level],appenderName,appenderName

​ log4j.rootLogger:表示输出的日志级别在level级别及以上的级别,意思就是只有级别大于或等于level才会

​ 在控制台或者日志文件中输出

​ level:表示日志的级别,日志的级别由高到低:ERROR,WARN,INFO,DEBUG

​ appenderName:表示日志输出的位置,可以是任意的单词,只要后面的配置跟这个单词匹配即可

log4j.appender.appenderName:表示日志输出类型,其中有如下几种配置

​ org.apache.log4j.ConsoleAppender:输出到控制台

​ org.apache.log4j.FileAppender:输出到文件,使用比较少

​ org.apache.log4j.DailyRollingFileAppender:表示每天产生一个日志文件

​ org.apache.log4j.RollingFileAppender:表示文件大小到达指定尺寸的时候产生一个新的文件

​ org.apache.log4j.WriterAppender:将日志信息以流格式发送到任意指定的地方,用的少

log4j.appender.appenderName.File:表示日志输出到哪个指定的文件中,使用如下

​ log4j.appender.appenderName.File = C://DEBUG.log

log4j.appender.appenderName.layout:日志信息格式,有如下几种配置

​ org.apache.log4j.HTMLLayout:以HTML表格形式布局

​ org.apache.log4j.PatternLayout:可以灵活地指定布局模式,常用

​ org.apache.log4j.SimpleLayout:包含日志信息的级别和信息字符串

​ org.apache.log4j.TTCCLayout:包含日志产生的时间、线程、类别等等信息

log4j.appender.appenderName.layout.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 输出日志事件的发生位置,及在代码中的行数;

log4j.appender.appenderName.Threshold:表示这个日志文件中只输出指定级别和指定级别以上的日志

log4j.logger.com.pengtxyl.netty.bio=bioAppender:表示将 com.pengtxyl.netty.bio 输出到 bioAppender 下

log4j.additivity.com.pengtxyl.netty.bio=false:表示com.pengtxyl.netty.bio下的日志不输出到根记录器下面,如

​ 果为true,表示com.pengtxyl.netty.bio包下的日志也会输出到根记录器下面

=================================================================================

如果想对不同的类输出不同的文件(以cn.com.Test为例),先要在Test.java中定义:

private static Log logger = LogFactory.getLog(Test.class);

然后在log4j.properties中加入:

log4j.logger.cn.com.Test= DEBUG, test

log4j.appender.test=org.apache.log4j.FileAppender

log4j.appender.test.File=${myweb.root}/WEB-INF/log/test.log

log4j.appender.test.layout=org.apache.log4j.PatternLayout

log4j.appender.test.layout.ConversionPattern=%d %p [%c] - %m%n

也就是让cn.com.Test中的logger使用log4j.appender.test所做的配置。

如果在同一类中需要输出多个日志文件呢?其实道理是一样的,先在Test.java中定义:

private static Log logger1 = LogFactory.getLog(“myTest1”);

private static Log logger2 = LogFactory.getLog(“myTest2”);

然后在log4j.properties中加入:

log4j.logger.myTest1= DEBUG, test1

log4j.appender.test1=org.apache.log4j.FileAppender

log4j.appender.test1.File=${myweb.root}/WEB-INF/log/test1.log

log4j.appender.test1.layout=org.apache.log4j.PatternLayout

log4j.appender.test1.layout.ConversionPattern=%d %p [%c] - %m%n

log4j.logger.myTest2= DEBUG, test2

log4j.appender.test2=org.apache.log4j.FileAppender

log4j.appender.test2.File=${myweb.root}/WEB-INF/log/test2.log

log4j.appender.test2.layout=org.apache.log4j.PatternLayout

log4j.appender.test2.layout.ConversionPattern=%d %p [%c] - %m%n

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值