一、logback簡介:
目前比較常用的ava日志框架:Logback、log4j、log4j2、JUL等等。
Logback是在log4j的基礎上重新開發的一套日志框架,是完全實現SLF4J接口API(也叫日志門面)。
Logback 的架構非常通用,可以應用于不同的環境。目前logback分為三個模塊,logback-core,logback-classic和logback-access。
logback-core模塊為其他兩個模塊奠定了基礎。logback-classic模塊原生實現了SLF4JAPI,因此您可以輕松地在logback和其他日志記錄框架(例如 log4j1.x或java.util.logging (JUL))之間來回切換。
logback-access模塊與Tomcat和 Jetty 等 Servlet容器集成,以提供HTTP訪問日志功能。請注意,您可以輕松地在logback-core之上構建自己的模塊。
二、 SpringBoot集成Logback
- 創建項目:不做過多的描述,不會點這里
- 導入pom依賴
<dependencies><!-- Spring Boot Starter --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><!-- Spring Boot Starter Logging (默認已經包含在starter中) --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies>
- 編寫logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration><!-- 控制臺輸出 --><appender name="console" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%white(%contextName - %d{yyyy-MM-dd HH:mm:ss}) %green([%c][%t][%L]) %highlight(%-5level) - %yellow(%msg%n)</pattern></encoder></appender><!-- 文件輸出 --><appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender"><file>logs/springboot.log</file><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><fileNamePattern>logs/springboot-%d{yyyy-MM-dd}.log</fileNamePattern><maxHistory>30</maxHistory></rollingPolicy><!--文件中的輸出格式--><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%c][%t][%L][%p] - %msg%n</pattern></encoder></appender><!-- 日志級別配置 --><root level="info"><appender-ref ref="console"/><appender-ref ref="file"/></root>
</configuration>
- 編寫Controller層
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;/*** @Author Ysl* @Date 2024/5/22* @name Myselflean**/
@RestController
public class LogController {private static final Logger log = LoggerFactory.getLogger(LogController.class);@GetMapping("/log")public String log() {log.info("開始輸出日志--------start");String msg = "編寫業務代碼";log.info("日志輸出結束--------end:"+ msg);return msg;}
}
- 輸入網址進行訪問:http://localhost:8080/log
- 控制臺輸出后會出現logs文件夾,里面存放.log日志
- 如果需要更改輸出格式,可在logback.xml中進行修改配置,可查相關資料完善。