欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot動態(tài)修改日志級別的操作

 更新時間:2021年07月23日 11:11:00   作者:斗者_2013  
這篇文章主要介紹了SpringBoot動態(tài)修改日志級別的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

前言

為了減少日志頻繁打印帶來的性能影響,線上環(huán)境設(shè)置的日志級別一般都相對較高。而當(dāng)出現(xiàn)生產(chǎn)問題需要排查的時候,可能需要適當(dāng)降低日志級別(例如DEBUG)來打印更多的日志信息幫助定位問題。

傳統(tǒng)的做法一般是:

1、配置里修改日志級別

2、重啟應(yīng)用

3、問題復(fù)現(xiàn)查看報錯日志排查問題

這個過程需要重啟應(yīng)用,比較麻煩,效率較低,而且針對大型在線項目,不可能隨便停機重啟。那么有沒有一種方式在不重啟應(yīng)用的情況下實現(xiàn)動態(tài)修改日志級別呢?

下面,讓老萬教你如何通過SpringBoot的actuator組件來實現(xiàn)動態(tài)修改日志級別。

一、添加依賴

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

二、配置actuator暴露的端口

#啟用actuator端口
management.endpoints.enabled-by-default=fasle
#設(shè)置actuator的訪問根路徑,默認是/actuator
management.endpoints.web.base-path=/message
#啟用的端點
management.endpoints.web.exposure.include=loggers

這里我修改了actuator的默認訪問路徑/actuator,改為/message,為的是和項目的基礎(chǔ)訪問路徑保存一致。

啟用端口的2中配置方法:

方式一:(推薦)

management.endpoints.web.exposure.include=loggers

方式二:(這種方式測試沒有生效)

management.endpoint.loggers.enabled=true

補充:如何禁用info端口

management.endpoints.enabled-by-default=false
management.endpoint.info.enabled=true

關(guān)于actuator組件被稱為spring boot的4大組件之一,功能強大,大家在網(wǎng)上自己找些資料進一步了解。

actuator的endpoint端口說明:

ID 描述 默認啟用
auditevents 顯示當(dāng)前應(yīng)用程序的審計事件信息 Yes
beans 顯示一個應(yīng)用中所有Spring Beans的完整列表 Yes
conditions 顯示配置類和自動配置類(configuration and auto-configuration classes)的狀態(tài)及它們被應(yīng)用或未被應(yīng)用的原因 Yes
configprops 顯示一個所有@ConfigurationProperties的集合列表 Yes
env 顯示來自Spring的 ConfigurableEnvironment的屬性 Yes
flyway 顯示數(shù)據(jù)庫遷移路徑,如果有的話 Yes
health 顯示應(yīng)用的健康信息(當(dāng)使用一個未認證連接訪問時顯示一個簡單的'status',使用認證連接訪問則顯示全部信息詳情) Yes
info 顯示任意的應(yīng)用信息 Yes
liquibase 展示任何Liquibase數(shù)據(jù)庫遷移路徑,如果有的話 Yes
metrics 展示當(dāng)前應(yīng)用的metrics信息 Yes
mappings 顯示一個所有@RequestMapping路徑的集合列表 Yes
scheduledtasks 顯示應(yīng)用程序中的計劃任務(wù) Yes
sessions 允許從Spring會話支持的會話存儲中檢索和刪除(retrieval and deletion)用戶會話。使用Spring Session對反應(yīng)性Web應(yīng)用程序的支持時不可用。 Yes
shutdown 允許應(yīng)用以優(yōu)雅的方式關(guān)閉(默認情況下不啟用) No
threaddump 執(zhí)行一個線程dump Yes

如果使用web應(yīng)用(Spring MVC, Spring WebFlux, 或者 Jersey),你還可以使用以下端點:

ID 描述 默認啟用
heapdum 返回一個GZip壓縮的hprof堆dump文件 Yes
jolokia 通過HTTP暴露JMX beans(當(dāng)Jolokia在類路徑上時,WebFlux不可用) Yes
logfile 返回日志文件內(nèi)容(如果設(shè)置了logging.file或logging.path屬性的話),支持使用HTTP Range頭接收日志文件內(nèi)容的部分信息 Yes
prometheus 以可以被Prometheus服務(wù)器抓取的格式顯示metrics信息 Yes

要更改公開哪些端點,請使用以下技術(shù)特定的include和exclude屬性:

Property Default
management.endpoints.jmx.exposure.exclude *
management.endpoints.jmx.exposure.include *
management.endpoints.web.exposure.exclude *
management.endpoints.web.exposure.include info, health

include屬性列出了公開的端點的ID,

exclude屬性列出了不應(yīng)該公開的端點的ID

exclude屬性優(yōu)先于include屬性。包含和排除屬性都可以使用端點ID列表進行配置。

*可以用來選擇所有端點。

例如,要通過HTTP公開除env和beans端點之外的所有內(nèi)容,請使用以下屬性:

management.endpoints.web.exposure.include=*
management.endpoints.web.exposure.exclude=env,beans

三、關(guān)閉鑒權(quán)

一般我們會將actuator和spring security鑒權(quán)組件結(jié)合使用,防止這些功能端口被隨便調(diào)用。由于這里是功能演示,先放開actuator相關(guān)端口的權(quán)限認證。

此外,如果存在Spring Security,則需要添加自定義安全配置,以允許對端點進行未經(jīng)身份驗證的訪問,如以下示例所示:放開所有Endpoint端點進行匹配

@Configuration
public class ActuatorSecurity extends WebSecurityConfigurerAdapter {
 
@Override
protected void configure(HttpSecurity http) throws Exception {
    http.requestMatcher(EndpointRequest.toAnyEndpoint()).authorizeRequests()
    .anyRequest().permitAll()
}

}

四 、通過/loggers端口查看日志級別

請求鏈接:http://localhost:8090/message/loggers

注意上面我說過的,我調(diào)整了management.endpoints.web.base-path=/message。如果沒有設(shè)置此參數(shù),則使用默認的/actuator去訪問。

在這里插入圖片描述

五、發(fā)起http請求修改日志級別

這里演示,修改目錄com.wxswj.provider.message.controller的日志級別為debug

請求類型為POST,參數(shù)格式是JSON

curl -H "Content-Type: application/json" -X POST --data 
'
{
    "configuredLevel": "DEBUG"
}
' 
http://localhost:8090/message/loggers/com.wxswj.provider.message.controller

大家可以在服務(wù)器上通過curl發(fā)起http請求,或者通過Postman發(fā)起請求。

curl -H "Content-Type: application/json" -X POST --data '{"configuredLevel": "DEBUG"}' http://localhost:8090/loggers/com.wxswj.provider.message.controller

六、查詢?nèi)罩炯墑e修改結(jié)果

http://localhost:8090/message/loggers/com.wxswj.provider.message.controller

{
"configuredLevel": "DEBUG",
"effectiveLevel": "DEBUG"
}

說明我們的修改日志級別的請求生效。

總結(jié)

通過整合spring boot的actuator組件,公開對應(yīng)的/loggers端口,我們就可以輕松的實現(xiàn)動態(tài)調(diào)整系統(tǒng)的日志級別,而不用項目重啟。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java 使用POI生成帶聯(lián)動下拉框的excel表格實例代碼

    Java 使用POI生成帶聯(lián)動下拉框的excel表格實例代碼

    本文通過實例代碼給大家分享Java 使用POI生成帶聯(lián)動下拉框的excel表格,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-09-09
  • Java多線程之synchronized關(guān)鍵字的使用

    Java多線程之synchronized關(guān)鍵字的使用

    這篇文章主要介紹了Java多線程之synchronized關(guān)鍵字的使用,文中有非常詳細的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • 解決poi導(dǎo)出時單元格樣式被覆蓋問題

    解決poi導(dǎo)出時單元格樣式被覆蓋問題

    這篇文章主要介紹了解決poi導(dǎo)出時單元格樣式被覆蓋問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java之String[] args含義及作用

    Java之String[] args含義及作用

    這篇文章主要介紹了Java之String[] args含義及作用,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Java通過Scanner了解if...else if語句

    Java通過Scanner了解if...else if語句

    這篇文章主要介紹了Java通過Scanner了解if...else if語句,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • synchronized?和?Lock?的異同點(如何讓選擇)

    synchronized?和?Lock?的異同點(如何讓選擇)

    這篇文章主要介紹了?synchronized和Lock的異同點(如何讓選擇),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • Java ArrayList如何實現(xiàn)生成不重復(fù)隨機數(shù)

    Java ArrayList如何實現(xiàn)生成不重復(fù)隨機數(shù)

    這篇文章主要介紹了Java ArrayList如何實現(xiàn)生成不重復(fù)隨機數(shù),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • Java獲取文件ContentType案例

    Java獲取文件ContentType案例

    這篇文章主要介紹了Java獲取文件ContentType案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 詳解MyBatis 常用寫法

    詳解MyBatis 常用寫法

    MyBatis 是一款優(yōu)秀的持久層框架,它支持定制化 SQL、存儲過程以及高級映射。這篇文章給大家介紹了MyBatis 常用寫法,感興趣的朋友跟隨小編一起看看吧
    2018-11-11
  • Java中的FutureTask源碼解析

    Java中的FutureTask源碼解析

    這篇文章主要介紹了Java中的FutureTask源碼解析,FutureTask是一個可取消的異步計算,這個類是Future的實現(xiàn)類,有開始和取消一個計算的方法,如果一個計算已經(jīng)完成可以查看結(jié)果,需要的朋友可以參考下
    2023-12-12

最新評論