1、日志介绍
用于记录系统中发生的各种事件。记录的位置常见的有:控制台、磁盘文件等
2、日志级别
日志级别从低到高:
TRACE、DEBUG、INFO、WARN、ERROR、 FATAL
3、日志作用
通过日志观察、分析项目的运行情况(项目维护)
通过日志分析用户的使用情况(大数据分析)
4、Log4j 1.x的使用
前言:在2021年12月10日凌晨log4j被JNDI的注入漏洞,影响甚大,建议使用logback,不过就算有漏洞也不影响学习
Log4j+Commons-Logging
项目中添加Log4j和Commons-Logging的依赖
<!-- https://mvnrepository.com/artifact/log4j/log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-logging/commons-logging -->
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
创建项目:
完整的pom文件:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>xyz.haijin</groupId>
<artifactId>log01</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<!-- https://mvnrepository.com/artifact/log4j/log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-logging/commons-logging -->
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
</project>
log4j.xml配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration PUBLIC "-//LOGGER"
"http://org/apache/log4j/xml/log4j.dtd">
<log4j:configuration>
<!-- org.apache.log4j.ConsoleAppender 输出到控制台 -->
<appender name="myConsole" class="org.apache.log4j.ConsoleAppender">
<!--输出格式-->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
</layout>
</appender>
<!-- 输出到文件 -->
<appender name="myFile1" class="org.apache.log4j.RollingFileAppender">
<param name="File" value="d:/log/hello.log"/><!--文件位置-->
<param name="Append" value="true"/><!--是否选择追加-->
<param name="MaxFileSize" value="1kb"/><!--文件最大字节数-->
<param name="MaxBackupIndex" value="2" /><!--新文件数量-->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n" />
</layout>
</appender>
<!-- 输出到文件 -->
<appender name="myFile2" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="d:/log/world.log"/><!--文件位置-->
<param name="Append" value="true"/><!--是否选择追加-->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
</layout>
</appender>
<!-- 根logger的设置-->
<root>
<!--优先级设置,all < trace < debug < info < warn < error < fatal < off -->
<priority value="all"/>
<appender-ref ref="myConsole"/>
<appender-ref ref="myFile1"/>
<appender-ref ref="myFile2"/>
</root>
</log4j:configuration>
配置文件说明:
占位符 | 描述 |
%p | 输出优先级,即DEBUG, INFO, WARN, ERROR, FATAL |
%r | 输出自应用启动到输出该log信息耗费的毫秒数 |
%c | 输出所在类的全名 |
%t | 输出产生该日志事件的线程名 |
%n | 输出一个回车换行符 |
%d | 输出日志时间点的日期或时间,默认格式为IS08601,也可以在其后指定格式,比如: %dyyy-MM-dd HH:mss,SSS},输出类 似: 2002- 10-1822:10:28,921 |
%l | 输出日志事件的发生位置,包括类名、发生的线程,以及在代码中的行数。举例: Testlo4.main(TestLog4.java:10) |
LogTest.java 代码:
package xyz.haijin.log.test;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.junit.Test;
public class LogTest {
// 日志对象
private Log log = LogFactory.getLog(LogTest.class);
@Test
public void test1(){
log.trace("hello trace5~~");
log.debug("hello debug5~~");
log.info("hello info5~~");
log.warn("hello warn5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.error("hello error5");
log.fatal("hello fatal5");
}
}
运行结果: