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

SpringBoot應(yīng)用監(jiān)控Actuator使用隱患及解決方案

 更新時(shí)間:2024年07月05日 09:23:48   作者:名字咋這么難起捏  
SpringBoot的Actuator 模塊提供了生產(chǎn)級(jí)別的功能,比如健康檢查,審計(jì),指標(biāo)收集,HTTP 跟蹤等,幫助我們監(jiān)控和管理Spring Boot 應(yīng)用,本文將給大家介紹SpringBoot應(yīng)用監(jiān)控Actuator使用隱患及解決方案,需要的朋友可以參考下

Actuator介紹

SpringBoot的Actuator 模塊提供了生產(chǎn)級(jí)別的功能,比如健康檢查,審計(jì),指標(biāo)收集,HTTP 跟蹤等,幫助我們監(jiān)控和管理Spring Boot 應(yīng)用。這個(gè)模塊是一個(gè)采集應(yīng)用內(nèi)部信息暴露給外部的模塊,如自動(dòng)化配置信息、創(chuàng)建的Spring beans信息、系統(tǒng)環(huán)境變量的配置信息以及Web請求的詳細(xì)信息等(上述的功能都可以通過HTTP 和 JMX 訪問)。如果使用不當(dāng)或者一些不經(jīng)意的疏忽,可能造成信息泄露等嚴(yán)重的安全隱患。(PS:樓主這里就因?yàn)槟惩碌氖韬錾暇€后被檢測到未授權(quán)訪問然后勒令整改的)

Actuator核心是:Endpoints,它用來監(jiān)視應(yīng)用程序及交互,actuator中內(nèi)置了非常多的Endpoints(如:health、info、beans、httptrace等等),但同時(shí)也允許用戶根據(jù)自己需求自定義端點(diǎn)。

Endpoints 主要分成兩類:原生端點(diǎn)和用戶自定義端點(diǎn);自定義端點(diǎn)主要是指擴(kuò)展性,用戶可以根據(jù)自己的實(shí)際應(yīng)用,定義一些比較關(guān)心的指標(biāo),在運(yùn)行期進(jìn)行監(jiān)控。

常見端點(diǎn)如下表格所示

EndPoints描述
auditevents公開當(dāng)前應(yīng)用程序的審核事件信息。
beans顯示應(yīng)用程序中所有Spring bean的完整列表。 
caches 暴露可用的緩存。
conditions顯示在配置和自動(dòng)配置類上評(píng)估的條件以及它們匹配或不匹配的原因。
configprops顯示所有的整理列表@ConfigurationProperties,查看配置屬性,包括默認(rèn)配置 
env 露出Spring的屬性的各種環(huán)境變量,后面可跟/{name}查看具體的值
flyway顯示已應(yīng)用的任何Flyway數(shù)據(jù)庫遷移。 
health顯示應(yīng)用健康信息,2.0以后需要在配置里show-details打開開關(guān) 
httptrace 顯示HTTP跟蹤信息,2.0以后需要手動(dòng)打開
info 顯示任意應(yīng)用信息,是在配置文件里自己定義的
integrationgraph 顯示Spring Integration圖。
loggers 顯示和修改應(yīng)用程序中記錄器的配置。
liquibase 顯示已應(yīng)用的任何Liquibase數(shù)據(jù)庫遷移。
scheduledtasks 顯示應(yīng)用程序中的計(jì)劃任務(wù)。

感興趣的小伙伴可自行查閱

使用Actuator

使用Actuator監(jiān)控只需要在Maven中引入依賴“spring-boot-starter-actuator”即可

        <!-- 監(jiān)控端點(diǎn)-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

在YML配置文件中配置actuator的訪問路徑,開放端口

management:
  endpoints:
    web:
      # actuator的訪問路徑,默認(rèn)/actuator
      base-path: /actuator
      # 設(shè)置是否暴露端點(diǎn) 默認(rèn)只有health和info可見
      exposure:
        # 如需暴漏指定端口,在下方輸入,端口名稱,多個(gè)端點(diǎn)之間用“,”分割。如:env,session。開放所        
        # 有用*號(hào)表示,如下所示
        include: "*"
  #新開監(jiān)控端口,不設(shè)置采取項(xiàng)目端口(默認(rèn))
  server:
    port: 8081  
  endpoint:
    health:
      # 顯示db、redis、rabbti連接情況等
      show-details: always 
    shutdown:
      enabled: true  

到這里引入Actuator已完成,啟動(dòng)項(xiàng)目在瀏覽器地址欄輸入項(xiàng)目路徑后拼上/actuator后即可訪問(注:如果上面配置過地址這里就不應(yīng)輸入/actuator,應(yīng)該為你配置的地址。如需查詢某一個(gè)端點(diǎn)就在/actuator后面拼接上。如env:localhost:8080/actuator/env)

配置Actuator可視化界面

看上圖所列出的讓人看得不是很清楚,這時(shí)候可以使用monitor來構(gòu)建界面,使用也很簡單,只需要引入“spring-boot-monitor”即可

        <dependency>
            <groupId>cn.pomit</groupId>
            <artifactId>spring-boot-monitor</artifactId>
            <version>0.0.4</version>
        </dependency>

引入完成后啟動(dòng)項(xiàng)目,這個(gè)時(shí)候就不是訪問/actuator而是/monitor來進(jìn)行訪問。

Actuator配置安全訪問

需要使用Actuator監(jiān)控服務(wù)端點(diǎn)情況時(shí),如果在本地的話問題不大,但是放到線上就會(huì)有問題。這個(gè)時(shí)候我們需要對(duì)Actuator進(jìn)行保護(hù)。

比如說限制開放某一端點(diǎn),我們可以在yml中配置(env舉例):

endpoint:
 env:
    enabled: false

也可以通過搭配security模塊來進(jìn)行登錄限制。

首先引入maven依賴“spring-boot-starter-security”依賴

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

在yml配置文件中定義賬號(hào)密碼(注:也可以不在配置文件中定義,在配置類中定義)

spring:
  security:
    user:
      name: root
      password: 123456
      roles: ADMIN

編寫配置類(注:SpringBoot2.0拋棄了之前的引用方式,故此使用配置類方法,該實(shí)例只針對(duì)actuator進(jìn)行攔截,各位可根據(jù)實(shí)際情況調(diào)整)

@Configuration
@EnableWebSecurity
public class WebSecurityConfigurer extends WebSecurityConfigurerAdapter {
 
    @Override
    protected void configure(HttpSecurity http) {
        http.csrf().disable();
        http.formLogin().and()
                .authorizeRequests()
                .antMatchers("/**actuator/**","/**monitor/**")
                .authenticated()
                .anyRequest()
                .permitAll()
                .and()
                .httpBasic();
    }
 
    //添加賬號(hào)、密碼、權(quán)限
    @Autowired
    public  void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
        auth.inMemoryAuthentication().passwordEncoder(new BCryptPasswordEncoder())
                .withUser("root")
                .password(new BCryptPasswordEncoder().encode("123456"))
                .roles("ADMIN");
    }
 
 
}

啟動(dòng)項(xiàng)目訪問該地址會(huì)自動(dòng)跳轉(zhuǎn)到登錄界面,使用配置好的賬號(hào)密碼登錄即可。

 注:也可更改驗(yàn)證步驟搭配數(shù)據(jù)庫進(jìn)行登錄,在此就不多說了感興趣的小伙伴可自行研究展開了

Actuator安全建議

  • 設(shè)置Actuator獨(dú)立端口,并且不對(duì)外開放
  • 設(shè)置特定訪問IP地址,非設(shè)定IP自動(dòng)攔截
  • 設(shè)置訪問路徑不采取默認(rèn)路徑
  • 按需開放端點(diǎn)
  • 搭配security模塊進(jìn)行訪問加密

以上就是SpringBoot應(yīng)用監(jiān)控Actuator使用隱患及解決方案的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot Actuator使用隱患的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Java 中實(shí)現(xiàn)異步的多種方式

    Java 中實(shí)現(xiàn)異步的多種方式

    文章介紹了Java中實(shí)現(xiàn)異步處理的幾種常見方式,每種方式都有其特點(diǎn)和適用場景,通過選擇合適的異步處理方式,可以提高程序的性能和可維護(hù)性,感興趣的朋友一起看看吧
    2025-03-03
  • Jenkins集成sonarQube實(shí)現(xiàn)代碼質(zhì)量檢查過程圖解

    Jenkins集成sonarQube實(shí)現(xiàn)代碼質(zhì)量檢查過程圖解

    這篇文章主要介紹了Jenkins集成sonarQube實(shí)現(xiàn)代碼質(zhì)量檢查過程圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Springboot轉(zhuǎn)發(fā)重定向?qū)崿F(xiàn)方式解析

    Springboot轉(zhuǎn)發(fā)重定向?qū)崿F(xiàn)方式解析

    這篇文章主要介紹了springboot轉(zhuǎn)發(fā)重定向?qū)崿F(xiàn)方式解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • 詳解springboot通過Async注解實(shí)現(xiàn)異步任務(wù)及回調(diào)的方法

    詳解springboot通過Async注解實(shí)現(xiàn)異步任務(wù)及回調(diào)的方法

    這篇文章主要介紹了springboot通過Async注解實(shí)現(xiàn)異步任務(wù)及回調(diào),文中通過一個(gè)簡單示例來直觀的理解什么是同步調(diào)用,在單元測試用例中,注入?SyncTask?對(duì)象,并在測試用例中執(zhí)行?doTaskOne(),doTaskTwo(),doTaskThree()?三個(gè)方法,具體實(shí)現(xiàn)方式跟隨小編一起看看吧
    2022-05-05
  • seata-1.4.0安裝及在springcloud中使用詳解

    seata-1.4.0安裝及在springcloud中使用詳解

    這篇文章主要介紹了seata-1.4.0安裝及在springcloud中使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • IDEA下使用MyBatisCodeHelper插件的方法詳解

    IDEA下使用MyBatisCodeHelper插件的方法詳解

    這篇文章主要介紹了IDEA下使用MyBatisCodeHelper插件的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java實(shí)現(xiàn)視頻格式轉(zhuǎn)化的操作代碼

    Java實(shí)現(xiàn)視頻格式轉(zhuǎn)化的操作代碼

    在當(dāng)今數(shù)字化時(shí)代,視頻已成為我們?nèi)粘I詈凸ぷ髦胁豢苫蛉钡囊徊糠?不同的設(shè)備和平臺(tái)可能支持不同的視頻格式,因此,視頻格式轉(zhuǎn)換的需求也日益增長,本文將介紹如何使用Java實(shí)現(xiàn)視頻格式轉(zhuǎn)換,需要的朋友可以參考下
    2025-01-01
  • 詳解SpringBoot如何自定義Starter

    詳解SpringBoot如何自定義Starter

    Starter是Spring Boot中的一個(gè)非常重要的概念,Starter相當(dāng)于模塊,它能將模塊所需的依賴整合起來并對(duì)模塊內(nèi)的Bean根據(jù)環(huán)境( 條件)進(jìn)行自動(dòng)配置。本文將介紹SpringBoot如何自定義Starter,感興趣的可以學(xué)習(xí)一下
    2021-12-12
  • Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能

    Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能

    這篇文章主要介紹了Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • Java8時(shí)間日期庫中的常用使用示例

    Java8時(shí)間日期庫中的常用使用示例

    這篇文章主要介紹了Java8時(shí)間日期庫中的20個(gè)常用使用示例,幫助大家更好學(xué)習(xí)Java8是如何處理時(shí)間及日期的方法,感興趣的朋友可以參考一下
    2016-02-02

最新評(píng)論