Springboot 整合logback日誌管理
springboot 版本 2.3java
1.spring-boot-starter\spring-boot-starter-web默認支持logback,不須要引入pom
2.logback的文件命名
官方推薦 | 默認讀取resources目錄下的 logback-spring.xml |
自定義位置 | application.yml中配置: ( logging.config: classpath:log/logback-spring.xml ; logging.level.root: info ) |
3.logback配置文件
3.1 LOG_HOME catalina.base 指同項目父目錄同級的目錄mysql
3.2 root.level 指定日誌級別web
<?xml version="1.0" encoding="UTF-8" ?> <configuration> <!--定義日誌文件的存儲地址 勿在 LogBack 的配置中使用相對路徑--> <property name="LOG_HOME" value="${catalina.base}/logs/" /> <!-- 控制檯輸出 --> <appender name="Stdout" class="ch.qos.logback.core.ConsoleAppender"> <!-- 日誌輸出編碼 --> <layout class="ch.qos.logback.classic.PatternLayout"> <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級別從左顯示5個字符寬度%msg:日誌消息,%n是換行符--> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n </pattern> </layout> </appender> <!-- 按照天天生成日誌文件 --> <appender name="RollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--日誌文件輸出的文件名--> <FileNamePattern>${LOG_HOME}/server.%d{yyyy-MM-dd}.log</FileNamePattern> <MaxHistory>30</MaxHistory> </rollingPolicy> <layout class="ch.qos.logback.classic.PatternLayout"> <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級別從左顯示5個字符寬度%msg:日誌消息,%n是換行符--> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n </pattern> </layout> <!--日誌文件最大的大小--> <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"> <MaxFileSize>10MB</MaxFileSize> </triggeringPolicy> </appender> <!-- 日誌輸出級別 --> <root level="warn"> <appender-ref ref="Stdout" /> <appender-ref ref="RollingFile" /> </root> <!--日誌異步到數據庫 --> <!-- <appender name="DB" class="ch.qos.logback.classic.db.DBAppender"> 日誌異步到數據庫 <connectionSource class="ch.qos.logback.core.db.DriverManagerConnectionSource"> 鏈接池 <dataSource class="com.mchange.v2.c3p0.ComboPooledDataSource"> <driverClass>com.mysql.jdbc.Driver</driverClass> <url>jdbc:mysql://127.0.0.1:3306/databaseName</url> <user>root</user> <password>root</password> </dataSource> </connectionSource> </appender> --> </configuration>
4. 在代碼中使用方式
4.1 在類中直接使用@slf4j註解,在代碼中直接使用log對象,須要引入 lombokspring
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency>
4.2 經過loggerFactory建立實例sql
import lombok.extern.slf4j.Slf4j; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/logback") /*1.經過@slf4j註解引入log實例*/ @Slf4j public class HelloController { /*2. 經過loggerFacotory建立logger實例*/ //private final static Logger log= LoggerFactory.getLogger(HelloController.class); @RequestMapping("/showinfo") @ResponseBody public String ShowInfo(){ log.info("hello!"); return "hello logback"; } }
5. 屏蔽日誌
application.properties 中配置數據庫
關閉 com.zhl.springbootlogback的日誌:springboot
logging.level.com.zhl.springbootlogback=off