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

聊一聊SpringBoot服務(wù)監(jiān)控機制

 更新時間:2021年04月07日 11:30:02   作者:雙子孤狼  
這篇文章主要介紹了聊一聊SpringBoot服務(wù)監(jiān)控機制,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

任何一個服務(wù)如果沒有監(jiān)控,那就是兩眼一抹黑,無法知道當前服務(wù)的運行情況,也就無法對可能出現(xiàn)的異常狀況進行很好的處理,所以對任意一個服務(wù)來說,監(jiān)控都是必不可少的。

就目前而言,大部分微服務(wù)應(yīng)用都是基于 SpringBoot 來構(gòu)建,所以了解 SpringBoot 的監(jiān)控特性是非常有必要的,而 SpringBoot 也提供了一些特性來幫助我們監(jiān)控應(yīng)用。

本文基于 SpringBoot 2.3.1.RELEASE 版本演示。

SpringBoot 監(jiān)控

SpringBoot 中的監(jiān)控可以分為 HTTP 端點和 JMX 兩種方式來監(jiān)控當前應(yīng)用的運行狀況和指標收集

HTTP Endpoints 監(jiān)控

執(zhí)行器端點允許您監(jiān)視應(yīng)用程序并與之交互。SpringBoot 包括許多內(nèi)置的端點,并允許我們添加自己的端點??梢酝ㄟ^ HTTPJMX 啟用或禁用每個端點,并公開(使其可以遠程訪問)。每個端點都有一個唯一的 id,訪問時可以通過如下地址進行訪問:http:ip:port/{id}(SpringBoot 1.x ),而在 SpringBoot 2.x 版本中,默認新增了一個 /actuator 作為基本路,訪問地址則對應(yīng)為 :http:ip:port/actuator/{id}。

使用 HTTP 監(jiān)控非常簡單,在 SpringBoot 項目中,引入如下依賴:

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

默認就可以通過地址 http:localhost:8080/actuator/health,訪問之后得到如下結(jié)果:

在這里插入圖片描述

SpringBoot 中提供了非常多的默認端點監(jiān)控,但是出于安全考慮,默認情況下有些端點并不是開啟狀態(tài),如 shutdown 端點就是默認關(guān)閉的。

內(nèi)置端點

SpringBoot 中默認提供的常用內(nèi)置端點如下:

端點 id 描述
auditevents 公開當前應(yīng)用程序的審計事件信息,需要 AuditEventRepository Bean。
beans 展示程序中所有的 Bean。
caches 公開可用的緩存。
conditions 展示配置類或者自動裝配類中的條件,以及它們匹配或者不匹配的原因。
configprops 顯示所有 @ConfigurationProperties 中的配置屬性。
env 顯示 ConfigurableEnvironment 中的所有環(huán)境。
health 顯示應(yīng)用程序運行狀況信息。
httptrace 顯示 HTTP 跟蹤信息(默認情況下統(tǒng)計最近 100 次請求),需要 HttpTraceRepository Bean。
info 顯示任意程序信息。
integrationgraph 顯示 Spring 集成圖,需要依賴 spring-integration-core。
loggers 展示和修改應(yīng)用中的 loggers 配置。
metrics 展示當前應(yīng)用監(jiān)控指標的度量。
mappings 展示所有 @RequestMapping 路徑。
scheduledtasks 展示應(yīng)用中的所有定時任務(wù)信息。
sessions 允許從 Spring 會話支持的會話存儲中檢索和刪除用戶會話。需要使用基于 Spring Session web應(yīng)用程序。
shutdown 優(yōu)雅的關(guān)閉程序,默認禁止了該端點的訪問。

雖然說這里的大部分端點都是默認開啟的,但是默認暴露(允許對外訪問)的只有 healthinfo 端點,所以如果需要允許端點對外暴露,可以通過如下配置(如果想要暴露所有的端點,則可以直接配置 "*" ):

management:
 endpoints:
  web:
   exposure:
    include: [health,info,mappings] //或者直接配置 "*"

另外,開啟或禁用某一個端點,也可以通過通過如下配置進行動態(tài)控制:

management.endpoint.<id>.enabled=true

接下來我們挑選幾個重點的端點來介紹一下。

health 端點

health 斷點默認只是展示當前應(yīng)用健康信息,但是我們可以通過另一個配置打開詳細信息,這樣不僅僅會監(jiān)控當前應(yīng)用,還會監(jiān)控與當前應(yīng)用相關(guān)的其他第三方應(yīng)用,如 Redis

management:
 endpoint:
  health:
   show-details: always

這個配置打開之后,我們連接上 Redis 之后再次訪問 health 端點,就可以展示 Redis 服務(wù)的健康信息了:

在這里插入圖片描述

loggers 端點

訪問 http://localhost:8080/actuator/loggers 可以查看當前應(yīng)用的日志級別等信息:

在這里插入圖片描述

這里面本身并不特別,但是有一個功能卻非常有用,比如我們生產(chǎn)環(huán)境日志級別一般都是 info,但是現(xiàn)在有一個 bug 通過 info 級別無法排查,那么我們就可以臨時修改 log 級別。

比如上圖中的 ROOT 節(jié)點是 info 級別,那么我們可以通過 postman 等工具來發(fā)一個 post 請求修改日志級別。

在這里插入圖片描述

修改之后就會發(fā)現(xiàn),日志由原來的 info 變成了 debug

在這里插入圖片描述

metrics 端點

metrics 是一個非常重要的監(jiān)控端點,其監(jiān)控內(nèi)容覆蓋了 JVM 內(nèi)存、堆、類加載、處理器和 tomcat 容器等一些重要指標:

在這里插入圖片描述

可以看到這里面包含了非常多的指標,任意訪問一個指標就可以查看對應(yīng)的指標信息:

在這里插入圖片描述

自定義監(jiān)控端點

通過上面的介紹,可以看到 SpringBoot 提供的監(jiān)控非常強大,但是就算再全面的監(jiān)控也不可能滿足所有人的需求,所以 SpringBoot 也支持自定義監(jiān)控端點。

自定義監(jiān)控端點常用注解

自定義一個監(jiān)控端點主要有如下常用注解:

  • @Endpoint:定義一個監(jiān)控端點,同時支持 HTTPJMX 兩種方式。
  • @WebEndpoint:定義一個監(jiān)控端點,只支持 HTTP 方式。
  • @JmxEndpoint:定義一個監(jiān)控端點,只支持 JMX 方式。

以上三個注解作用在類上,表示當前類是一個監(jiān)控端點,另外還有一些注解會用在方法和參數(shù)上:

  • @ReadOperation:作用在方法上,可用來返回端點展示的信息(通過 Get 方法請求)。
  • @WriteOperation:作用在方法上,可用來修改端點展示的信息(通過 Post 方法請求)。
  • @DeleteOperation:作用在方法上,可用來刪除對應(yīng)端點信息(通過 Delete 方法請求)。
  • @Selector:作用在參數(shù)上,用來定位一個端點的具體指標路由。

來,一起寫一個自己的監(jiān)控端點

定義一個類,并使用 @Endpoint 注解標注標識,同時定義幾個方法用 @ReadOperation@WriteOperation 注解來標注:

@Endpoint(id="myEndpoint")
@Component
public class MyEndpoint {
  private String STATUS = "up";
  private String DETAIL = "一切正常";

//  @ReadOperation
//  public String test1(){
//    return "wolf";
//  }

//  @ReadOperation
//  public Map<String,String> test2(){
//    Map<String,String> map = new HashMap();
//    map.put("status","up");
//    return map;
//  }

  @ReadOperation
  public JSONObject test3(){
    JSONObject jsonObject= new JSONObject();
    jsonObject.put("status",STATUS);
    jsonObject.put("detail",DETAIL);
    return jsonObject;
  }

  @ReadOperation
  public JSONObject test3_1(@Selector String name){
    JSONObject jsonObject= new JSONObject();
    if ("status".equals(name)){
      jsonObject.put("status",STATUS);
    }else if ("detail".equals(name)){
      jsonObject.put("detail",DETAIL);
    }
    return jsonObject;
  }

  @WriteOperation//動態(tài)修改指標
  public void test4(@Selector String name,@Nullable String value){
    if (!StringUtils.isEmpty(value)){
      if ("status".equals(name)){
        STATUS = value;
      }else if ("detail".equals(name)){
        DETAIL = value;
      }
    }
  }
}

@Component 注解表示將該類交給 Spring 進行管理,或者也可以再定義一個 Configuration 類來加載該 Bean 也可以,當然,如果我們需要提供給第三方使用,如果無法保證當前包名被掃描,則需要使用 SpringBoot 的自動裝配機制將該類進行管理。

@ReadOperation 方法可以返回 String 或者 JSONObject 或者 Map 集合等。參數(shù)上加了 @Selector 注解則表示訪問斷端點的時候可以直接訪問子節(jié)點。

完成了上面的類,啟動 SpringBoot 應(yīng)用,接下來就可以直接通過 http://localhost:8080/actuator/myEndpoint 進行訪問了:

在這里插入圖片描述

同時,因為 test3_1 方法使用了 @Selector 注解,所以我們可以通過這個方法每一個指標的明細:

在這里插入圖片描述

而帶有 @WriteOperation 注解的方法可以用來修改指標,這個方法需要用 post 進行訪問,訪問的參數(shù)可以直接使用字符串傳參,也可以直接使用 json 進行傳參,修改之后再次查看就可以發(fā)現(xiàn)指標已經(jīng)被動態(tài)修改:

在這里插入圖片描述

JMX 監(jiān)控

JMX 全稱為 Java Management Extensions,即 Java 管理擴展。它提供了對 Java 應(yīng)用程序和 JVM 的監(jiān)控管理。通過JMX 我們可以監(jiān)控服務(wù)器中各種資源的使用情況以及線程,內(nèi)存和 CPU 等使用情況。

打開 jdk 下提供的工具 jConsole

在這里插入圖片描述

打開之后這里會監(jiān)控到我們已經(jīng)啟動的應(yīng)用,雙擊進入:

在這里插入圖片描述

如何手動注冊一個 JMX MBean

定義一個接口 SystemInfoMBean(注意名字必須要用 MBean 結(jié)尾):

public interface SystemInfoMBean {
  int getCpuCore();
  long getTotalMemory();
  void shutdown();
}

再定義一個類實現(xiàn) SystemInfoMBean 接口,實現(xiàn)類的明明方式為接口名去掉 MBean

public class SystemInfo implements SystemInfoMBean {
  @Override
  public int getCpuCore() {
    return Runtime.getRuntime().availableProcessors();
  }
  @Override
  public long getTotalMemory() {
    return Runtime.getRuntime().totalMemory();
  }

  @Override
  public void shutdown() {
    System.exit(0);
  }
}

最后就是需要將該實現(xiàn)類進行注冊:

public class JmxRegisterMain {
  public static void main(String[] args) throws NotCompliantMBeanException, InstanceAlreadyExistsException, MBeanRegistrationException, MalformedObjectNameException, IOException {
    MBeanServer mBeanServer= ManagementFactory.getPlatformMBeanServer();
    ObjectName objectName=new ObjectName("com.lonely.wolf.note.springboot.actuator.jmx:type=SystemInfo");
    SystemInfo SystemInfo =new SystemInfo();
    mBeanServer.registerMBean(SystemInfo,objectName);//注冊
    System.in.read();//防止程序結(jié)束
  }
}

運行該 main 方法,再打開 jConsole 就可以看到成功注冊了一個 MBean

在這里插入圖片描述

同樣的,Spring 當中只要我們使用了 @@Endpoint 或者 @JmxEndpoint 注解,就會自動幫我們注冊一個 MBean,其原理也是利用了自動裝配機制。

其他監(jiān)控

除了 SpringBoot 自帶的監(jiān)控之外,也有其他第三方開源的強大監(jiān)控系統(tǒng),如 Prometheus,而且 SpringBoot 也將其進行了集成,使用 Prometheus 時只需要引入如下 jar 包即可:

<dependency>
  <groupId>io.micrometer</groupId>
  <artifactId>micrometer-registry-prometheus</artifactId>
</dependency>

當然,如果使用 Prometheus 的話需要單獨安裝,而且一般會選擇 Prometheus + Grafana 來共同實現(xiàn)一個監(jiān)控平臺,在這里就不做過多介紹,如果感興趣的朋友可以自己去了解下這兩種軟件的使用。

總結(jié)

本文主要講述了 Spring Boot actuator 的使用,并分別介紹了其中兩種監(jiān)控類型 HTTPJMX,最后通過一個例子來實現(xiàn)了自定義的端點,同時也實現(xiàn)了手動注冊一個 MBean 的方法。

到此這篇關(guān)于聊一聊SpringBoot服務(wù)監(jiān)控機制的文章就介紹到這了,更多相關(guān)SpringBoot服務(wù)監(jiān)控機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java簡單操作word實例

    java簡單操作word實例

    這篇文章主要為大家詳細介紹了java簡單操作word實例,感興趣的朋友可以參考一下
    2016-03-03
  • RocketMQ保證消息的有序性的案例分享

    RocketMQ保證消息的有序性的案例分享

    Apache RocketMQ 是一個常用的開源消息中間件,它提供了強大的有序消息處理能力,這里我們會探討 RocketMQ 是如何保證消息的有序性的,包括其設(shè)計原理和相關(guān)的源碼實現(xiàn),需要的朋友可以參考下
    2024-04-04
  • Quarkus中的依賴注入DI和面向切面aop編程

    Quarkus中的依賴注入DI和面向切面aop編程

    這篇文章主要為大家介紹了Quarkus中的依賴注入DI和面向切面aop的編程規(guī)范思想,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2022-02-02
  • Java 工具類總結(jié)目錄(分享)

    Java 工具類總結(jié)目錄(分享)

    下面小編就為大家?guī)硪黄狫ava 工具類總結(jié)目錄(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • spring mvc中的@ModelAttribute注解示例介紹

    spring mvc中的@ModelAttribute注解示例介紹

    在Spring mvc中,注解@ModelAttribute是一個非常常用的注解,下面這篇文章主要給大家介紹了關(guān)于spring mvc中@ModelAttribute注解的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。
    2017-09-09
  • SpringBoot使用Spring Test進行集成測試的流程步驟

    SpringBoot使用Spring Test進行集成測試的流程步驟

    Spring Test 是 Spring Framework 提供的一個測試框架,它可以幫助我們進行集成測試,在本文中,我們將介紹如何使用 Spring Test 進行集成測試,需要的朋友可以參考下
    2023-06-06
  • Java簡單實現(xiàn)線程池

    Java簡單實現(xiàn)線程池

    這篇文章主要為大家詳細介紹了Java簡單實現(xiàn)線程池,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • 關(guān)于thymeleaf判斷對象是否為空的相關(guān)邏輯處理

    關(guān)于thymeleaf判斷對象是否為空的相關(guān)邏輯處理

    這篇文章主要介紹了關(guān)于thymeleaf判斷對象是否為空的相關(guān)邏輯處理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • idea文件被鎖無法更改問題

    idea文件被鎖無法更改問題

    這篇文章主要介紹了idea文件被鎖無法更改問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Java中String、StringBuffer、StringBuilder的區(qū)別詳解

    Java中String、StringBuffer、StringBuilder的區(qū)別詳解

    java中String、StringBuffer、StringBuilder是編程中經(jīng)常使用的字符串類,他們之間有什么區(qū)別呢?下面小編給大家總結(jié)了Java中String、StringBuffer、StringBuilder的區(qū)別詳解,需要的朋友參考下吧
    2016-06-06

最新評論