# 整合 log4j 日志

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter</artifactId>
  <exclusions>
    <!--   排除 spring 自己的日志,后续需要整合其他的日志框架-->
    <exclusion>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-logging</artifactId>
    </exclusion>
  </exclusions>
</dependency>
1
2
3
4
5
6
7
8
9
10
11

Spring Boot 自带了一个日志实现,老师的意思是:它自带的实现引用有点多,我们并不需要那么多,所以由我们自己自行实现日志

引入 log4j 实现

<!-- 引入日志依赖:抽象层 与 实现层 -->
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-api</artifactId>
  <version>1.7.21</version>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-log4j12</artifactId>
  <version>1.7.21</version>
</dependency>
1
2
3
4
5
6
7
8
9
10
11

创建 log4j.properties 文件

log4j.rootLogger=DEBUG,stdout,file
log4j.additivity.org.apache=true

# 控制台打印
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.threshold=INFO
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%-5p %c{1}:%L - %m%n

# 按天滚动保存日志
log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.DatePattern='.'yyyy-MM-dd-HH-mm
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
log4j.appender.file.Threshold=INFO
log4j.appender.file.append=true
log4j.appender.file.File=./logs/foodie-api/imooc.log
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17