7、log4j-自定义logger的配置

log4j.properties


# 设置root logger等级为ALL,且appender有A1和FILE
log4j.rootLogger=ALL, A1,A3

#设置com.example.test logger
log4j.logger.com.example.test=DEBUG,A1,A3
# 取消继承父类
log4j.additivity.com.example.test=false

# 设置个控制台输出源,该appender名叫:A1
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n


#设置个文件输出源,该appender名叫:FILE
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.file=D:/logs/log4j.log
log4j.appender.FILE.append=true
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n


#设置个文件输出源(滚动文件输出源,按照文件大小重新生成临时文件),该appender名叫:A2
log4j.appender.A2=org.apache.log4j.RollingFileAppender
log4j.appender.A2.file=D:/logs/log4j.log
log4j.appender.A2.append=true
#maxFileSize  文件最大大小,超过会将旧的数据放在临时文件,新的日志继续打印在file指定的文件名中
log4j.appender.A2.maxFileSize=1
#maxBackupIndex  文件最大备份数,认为1
log4j.appender.A2.maxBackupIndex=10
log4j.appender.A2.layout=org.apache.log4j.PatternLayout
log4j.appender.A2.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n



#设置个文件输出源(滚动文件输出源,按照日期重新生成临时文件),认按照天分割日志,该appender名叫:A3
log4j.appender.A3=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A3.file=D:/logs/log4j.log
log4j.appender.A3.layout=org.apache.log4j.PatternLayout
log4j.appender.A3.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n

测试代码

package com.example.test;

import java.io.PrintWriter;

import org.apache.log4j.BasicConfigurator;
import org.apache.log4j.ConsoleAppender;
import org.apache.log4j.Layout;
import org.apache.log4j.Logger;
import org.apache.log4j.PatternLayout;
import org.apache.log4j.SimpleLayout;
import org.apache.log4j.spi.LoggingEvent;
import org.junit.Test;

public class TestLog4j {

	private static final Logger logger = Logger.getLogger(TestLog4j.class);
	
	@Test
	public void testLog4j() {
		// 日志级别 
		logger.fatal("fatal"); // 严重错误,一般会造成系统崩溃 和终止运行 
		logger.error("error"); // 错误信息,但不会影响系统运行 
		logger.warn("warn"); // 警告信息,可能会发生问题 
		logger.info("info"); // 程序运行信息,数据库的连接、网 络、IO操作等 
		logger.debug("debug"); // 调试信息,一般在开发阶段使 用,记录程序的变量、参数等 
		logger.trace("trace"); // 追踪信息,记录程序的所有流程 信息
	}
}

结果运行图

在这里插入图片描述

相关文章

可以认为OpenFeign是Feign的增强版,不同的是OpenFeign支持S...
为进一步规范小程序交易生态、提升用户购物体验、满足用户在...
云原生之使用Docker部署Dashdot服务器仪表盘
本文主要描述TensorFlow之回归模型的基本原理
1.漏洞描述Apache Druid 是一个集时间序列数据库、数据仓库和...
内部类(当作类中的一个普通成员变量,只不过此成员变量是cl...