亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

springboot 日志實現過程

 更新時間:2025年01月08日 11:41:20   作者:Leaf吧  
Spring Boot 使用 SLF4J 作為日志門面,Logback 或 Log4j2 作為日志實現,日志門面提供統(tǒng)一接口,簡化日志記錄,實現負責具體功能,Spring Boot 默認使用 SLF4J 和 Logback,可以通過配置文件或注解進行日志記錄和控制,感興趣的朋友一起看看吧

日志

日志框架可以分為 日志門面(Facade) 和 日志實現(Implementation),Spring Boot 使用了 SLF4J 作為日志門面,Logback 或 Log4j2 作為日志實現。

日志門面以及日志實現

日志門面

日志門面(Facade)
日志門面 是一個設計模式中的“門面模式(Facade Pattern)”,它提供了統(tǒng)一的接口,簡化了日志記錄的使用,屏蔽了不同日志框架之間的細節(jié)。
門面本身并不實現日志的具體記錄功能,它只是提供了日志記錄的 API 規(guī)范,開發(fā)者通過這些規(guī)范來記錄日志。
典型的日志門面框架是 SLF4J(Simple Logging Facade for Java),它定義了一組通用的日志接口,開發(fā)者通過這些接口來進行日志記錄。

日志實現

日志實現 是實際執(zhí)行日志記錄的組件,它負責處理日志的輸出、格式化、存儲等具體功能。
日志實現提供了對日志的具體管理方式,包括日志級別、輸出位置、格式、日志文件的滾動與清理等。
常見的日志實現框架有:
Logback:Spring Boot 默認使用的日志框架,提供了功能豐富的日志管理和配置。
Log4j2:Apache 提供的日志框架,相較于 Logback 提供了更多的性能優(yōu)化(如異步日志處理)和擴展性。

兩者關系

門面(Facade) 是日志框架的統(tǒng)一接口,開發(fā)者通過它來調用日志功能。
實現(Implementation) 是執(zhí)行日志記錄、管理和配置的具體框架,處理如何生成、存儲和輸出日志。

springboot中日志的配置

Spring Boot 默認配置 中,SLF4J 是日志門面Logback 是默認的日志實現框架。你無需做任何特別的配置,只要在 Spring Boot 項目中添加了相關依賴,Spring Boot 會自動配置日志系統(tǒng)。
當你在代碼中使用 SLF4J 的日志接口時(例如:Logger logger = LoggerFactory.getLogger(YourClass.class)),日志實際上會被傳遞給 Logback(或者 Log4j2)。

如何使用slf4j進行日志記錄

通過 SLF4J 提供的日志接口進行日志記錄

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class MyService {
    private static final Logger logger = LoggerFactory.getLogger(MyService.class);
    public void doSomething() {
        logger.info("Starting the task...");
        try {
            // 執(zhí)行任務
        } catch (Exception e) {
            logger.error("An error occurred", e);
        }
    }
}

LoggerFactory.getLogger(MyService.class) 獲取了一個 Logger 實例,這個實例是通過 SLF4J 提供的 API 來使用的。你通過這個 Logger 來記錄日志(如 info, error 等)。
但是,日志實際的記錄過程是由 Logback 或 Log4j2 執(zhí)行的,這些框架提供了具體的日志輸出方式、格式化和管理機制。

優(yōu)化 使用Lombok 依賴

再pom.xml文件添加lombok依賴

    <dependency>
        <groupId>org.project.lombok<groupId>
        <artifactId>lombok<artifactId>
    <dependency>

再類上添加@Slf4j注解,然后直接使用log.info(“日志”);

@Service
@Slf4j
public class TestServiceImpl  implements TestService{
    @Resource(name = "poolExecutor")
    private ThreadPoolTaskExecutor executor;
    @Override
    public String test() {
        ThreadPoolTaskExecutor taskExecutor = executor;
        // 獲取線程池信息
        int activeCount = taskExecutor.getActiveCount();
        int corePoolSize = taskExecutor.getCorePoolSize();
        int poolSize = taskExecutor.getPoolSize();
        taskExecutor.execute(()->{
                System.out.printf(activeCount+"--"+corePoolSize);
        });
        log.info("日志");
        return null;
    }
}

如何控制日志輸出

控制日志輸出就需要日志實現了logback或者log4j2
這里使用logback舉例
Spring Boot 支持兩種日志配置方式:通過 application.yml/application.properties 文件配置 和 通過 logback-spring.xml 配置文件進行詳細配置。這兩種方式各有不同的適用場景

application.yml

示例

logging:
  level:
    root: INFO  # 根日志級別
    com.example: DEBUG  # 某個包的日志級別
  file:
    name: E:\IDE\demlNewLog\myapp.log  # 日志文件路徑
    path: E:\IDE\demlNewLog
  pattern:
    console: "%d{yyyy-MM-dd HH:mm:ss} - %msg%n"  # 控制臺輸出格式

logback-spring.xml

當你需要更細致地控制日志行為(如日志的滾動策略、異步日志、日志文件分割、過濾器等高級功能)時,你可以使用 logback-spring.xml 配置文件。這種方式提供了非常靈活和強大的日志配置能力。

創(chuàng)建 logback-spring.xml 配置文件: 將 logback-spring.xml 文件放在 src/main/resources 目錄下,這樣 Spring Boot 會自動讀取該文件。名字必須是 logback-spring.xml(springboot專有的)才能覆蓋logback配置

Spring Boot 自動讀取 logback-spring.xml 配置

如果存在 logback-spring.xml 配置文件,Spring Boot 會自動加載它,覆蓋默認的 Logback 配置。
logback-spring.xml 文件與普通的 logback.xml 文件的不同之處在于,logback-spring.xml 文件支持 Spring 的配置和屬性注入,例如可以使用 Spring 的 PropertySource 來動態(tài)設置日志級別、輸出路徑等。

再resource目錄下創(chuàng)建logback-spring.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
    <!-- appender是configuration的子節(jié)點,是負責寫日志的組件。 -->
    <!-- ConsoleAppender:把日志輸出到控制臺 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <!-- 默認情況下,每個日志事件都會立即刷新到基礎輸出流。 這種默認方法更安全,因為如果應用程序在沒有正確關閉appender的情況下退出,則日志事件不會丟失。但是,為了顯著增加日志記錄吞吐量,可以將immediateFlush屬性設置為false -->
        <!--<immediateFlush>true</immediateFlush>-->
        <encoder>
            <!-- %37():如果字符沒有37個字符長度,則左側用空格補齊 -->
            <!-- %-37():如果字符沒有37個字符長度,則右側用空格補齊 -->
            <!-- %15.15():如果記錄的線程字符長度小于15(第一個)則用空格在左側補齊,如果字符長度大于15(第二個),則從開頭開始截斷多余的字符 -->
            <!-- %-40.40():如果記錄的logger字符長度小于40(第一個)則用空格在右側補齊,如果字符長度大于40(第二個),則從開頭開始截斷多余的字符 -->
            <!-- %msg:日志打印詳情 -->
            <!-- %n:換行符 -->
            <!-- %highlight():轉換說明符以粗體紅色顯示其級別為ERROR的事件,紅色為WARN,BLUE為INFO,以及其他級別的默認顏色。 -->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %highlight(%-5level) --- [%15.15(%thread)] %cyan(%-40.40(%logger{40})) : %msg%n</pattern>
            <!-- 控制臺也要使用UTF-8,不要使用GBK,否則會中文亂碼 -->
            <charset>UTF-8</charset>
        </encoder>
    </appender>
    <!-- info 日志文件-->
    <!-- RollingFileAppender:滾動記錄文件,先將日志記錄到指定文件,當符合某個條件時,將日志記錄到其他文件 -->
    <!-- 以下的大概意思是:
		1.先按日期存日志,日期變了,將前一天的日志文件名重命名為XXX%日期%索引,新的日志仍然是project_info.log
    	2.如果日期沒有發(fā)生變化,但是當前日志的文件大小超過10MB時,對當前日志進行分割 重命名-->
    <appender name="info_log" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--日志文件路徑和名稱-->
        <File>E:\IDE\demlNewLog\info.log</File>
        <!--是否追加到文件末尾,默認為true-->
        <append>true</append>
        <!-- 打印除了ERROR的日志 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <onMatch>DENY</onMatch> <!-- 如果命中ERROR就禁止這條日志 -->
            <onMismatch>ACCEPT</onMismatch> <!-- 如果沒有命中就使用這條規(guī)則 -->
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!-- 日志文件的名字會根據fileNamePattern的值,每隔一段時間改變一次 -->
            <!-- 文件名示例:logs/project_info.2017-12-05.0.log -->
            <!-- 注意:SizeAndTimeBasedRollingPolicy中 %i和%d令牌都是強制性的,必須存在,否則報錯 -->
            <fileNamePattern>logs/project_info.%d.%i.log</fileNamePattern>
            <!-- 每產生一個日志文件,該日志文件的保存期限為30天 -->
            <!-- 注:maxHistory的單位是根據fileNamePattern中的翻轉策略自動推算出來的,例如上面選用了yyyy-MM-dd,則單位為天,如果上面選用了yyyy-MM,則單位為月。另外上面的單位默認為yyyy-MM-dd-->
            <maxHistory>30</maxHistory>
            <!-- 每個日志文件到10mb的時候開始切分,最多保留30天,但最大到20GB,哪怕沒到30天也要刪除多余的日志 -->
            <totalSizeCap>20GB</totalSizeCap>
            <!-- maxFileSize:這是活動文件的大小,默認值是10MB,測試時可改成5KB看效果 -->
            <maxFileSize>10MB</maxFileSize>
        </rollingPolicy>
        <!--編碼器-->
        <encoder>
            <!-- pattern節(jié)點,用來設置日志的輸入格式 ps:日志文件中不要設置顏色,否則顏色部分會有ESC[0:39em等亂碼-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level --- [%15.15(%thread)] %-40.40(%logger{40}) : %msg%n</pattern>
            <!-- 記錄日志的編碼:此處設置字符集 - -->
            <charset>UTF-8</charset>
        </encoder>
    </appender>
    <!-- error 日志文件-->
    <appender name="error_log" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--日志文件路徑和名稱-->
        <File>E:\IDE\demlNewLog\error.log</File>
        <!--是否追加到文件末尾,默認為true-->
        <append>true</append>
        <!-- ThresholdFilter過濾低于指定閾值的事件。 對于等于或高于閾值的事件,ThresholdFilter將在調用其decision()方法時響應NEUTRAL。 但是,將拒絕級別低于閾值的事件 -->
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <!-- 低于ERROR級別的日志(debug,info)將被拒絕,等于或者高于ERROR的級別將相應NEUTRAL -->
            <level>ERROR</level>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!-- 活動文件的名字會根據fileNamePattern的值,每隔一段時間改變一次 -->
            <!-- 文件名示例:logs/project_error.2017-12-05.0.log -->
            <!-- 注意:SizeAndTimeBasedRollingPolicy中 %i和%d令牌都是強制性的,必須存在,要不會報錯 -->
            <fileNamePattern>logs/project_error.%d.%i.log</fileNamePattern>
            <!-- 每產生一個日志文件,該日志文件的保存期限為30天 -->
            <maxHistory>30</maxHistory>
            <!-- 每個日志文件到10mb的時候開始切分,最多保留30天,但最大到20GB,哪怕沒到30天也要刪除多余的日志 -->
            <totalSizeCap>20GB</totalSizeCap>
            <!-- maxFileSize:這是活動文件的大小,默認值是10MB,測試時可改成5KB看效果 -->
            <maxFileSize>10MB</maxFileSize>
        </rollingPolicy>
        <!--編碼器-->
        <encoder>
            <!-- pattern節(jié)點,用來設置日志的輸入格式-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level --- [%15.15(%thread)] %-40.40(%logger{40}) : %msg%n</pattern>
            <!-- 記錄日志的編碼:此處設置字符集 - -->
            <charset>UTF-8</charset>
        </encoder>
    </appender>
    <!-- configuration中最多允許一個root,別的logger如果沒有設置級別則從父級別root繼承 -->
    <root level="INFO">
        <appender-ref ref="STDOUT" />
    </root>
    <!-- name屬性指定項目中某個包,當有日志操作行為時的日志記錄級別 -->
    <logger name="com.example.demonew.controller" level="INFO">
        <appender-ref ref="info_log" />
        <appender-ref ref="error_log" />
    </logger>
    <!-- 利用logback輸入mybatis的sql日志,
    注意:如果不加 additivity="false" 則此logger會將輸出轉發(fā)到自身以及祖先的logger中,就會出現日志文件中sql重復打印-->
    <logger name="com.example.demonew.service" level="DEBUG" additivity="false">
        <appender-ref ref="info_log" />
        <appender-ref ref="error_log" />
    </logger>
    <!-- additivity=false代表禁止默認累計的行為,即com.atomikos中的日志只會記錄到日志文件中,不會輸出層次級別更高的任何appender-->
    <logger name="com.example" level="INFO" additivity="false">
        <appender-ref ref="info_log" />
        <appender-ref ref="error_log" />
    </logger>
</configuration>

到此這篇關于springboot 日志實現的文章就介紹到這了,更多相關springboot 日志實現內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java動態(tài)代理實現_動力節(jié)點Java學院整理

    Java動態(tài)代理實現_動力節(jié)點Java學院整理

    動態(tài)代理作為代理模式的一種擴展形式,廣泛應用于框架(尤其是基于AOP的框架)的設計與開發(fā),本文將通過實例來講解Java動態(tài)代理的實現過程
    2017-08-08
  • Java中的Timer與TimerTask源碼及使用解析

    Java中的Timer與TimerTask源碼及使用解析

    這篇文章主要介紹了Java中的Timer與TimerTask源碼及使用解析,在Java中,經常使用Timer來定時調度任務,Timer調度任務有一次性調度和循環(huán)調度,循環(huán)調度有分為固定速率調度(fixRate)和固定時延調度(fixDelay),需要的朋友可以參考下
    2023-10-10
  • Java利用redis zset實現延時任務詳解

    Java利用redis zset實現延時任務詳解

    zset作為redis的有序集合數據結構存在,排序的依據就是score。本文就將利用zset score這個排序的這個特性,來實現延時任務,感興趣的可以了解一下
    2022-08-08
  • 詳解SpringBoot緩存的實例代碼(EhCache 2.x 篇)

    詳解SpringBoot緩存的實例代碼(EhCache 2.x 篇)

    這篇文章主要介紹了詳解SpringBoot緩存的實例代碼(EhCache 2.x 篇),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Springboot應用中線程池配置詳細教程(最新2021版)

    Springboot應用中線程池配置詳細教程(最新2021版)

    這篇文章主要介紹了Springboot應用中線程池配置教程(2021版),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • SpringBoot3整合Druid監(jiān)控功能的項目實踐

    SpringBoot3整合Druid監(jiān)控功能的項目實踐

    Druid連接池作為一款強大的數據庫連接池,提供了豐富的監(jiān)控和管理功能,成為很多Java項目的首選,本文主要介紹了SpringBoot3整合Druid監(jiān)控功能的項目實踐,感興趣的可以了解一下
    2024-01-01
  • SpringBoot實現的Mongodb管理工具使用解析

    SpringBoot實現的Mongodb管理工具使用解析

    這篇文章主要介紹了SpringBoot實現的Mongodb管理工具使用解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • Java中Array、List、Map相互轉換的方法詳解

    Java中Array、List、Map相互轉換的方法詳解

    這篇文章主要介紹了Java中Array、List、Map相互轉換的方法詳解,在實際項目開發(fā)中或者一些算法面試題目中經常需要用到Java中這三種類型的相互轉換,比如對于一個整型數組中尋找一個整數與所給的一個整數值相同,需要的朋友可以參考下
    2023-08-08
  • SpringBoot jackson 精度處理問題解決

    SpringBoot jackson 精度處理問題解決

    由于JavaScript處理的最大數值限制,較大的雪花ID在JS中容易溢出,為解決此問題,可在SpringMVC或SpringBoot中使用@RequestBody注解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-10-10
  • 深入學習SpringCloud之SpringCloud簡介

    深入學習SpringCloud之SpringCloud簡介

    Spring Cloud是一個一站式的開發(fā)分布式系統(tǒng)的框架,為開發(fā)者提供了一系列的構建分布式系統(tǒng)的工具集,本文給大家介紹springcloud的相關知識,感興趣的朋友跟隨一起看看吧
    2021-04-04

最新評論