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

Java之SpringCloudAlibaba Sentinel組件案例講解

 更新時間:2021年07月28日 09:01:32   作者:小小張自由—>張有博  
這篇文章主要介紹了Java之SpringCloudAlibaba Sentinel組件案例講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下

Sentinel 是什么

隨著微服務(wù)的流行,服務(wù)和服務(wù)之間的穩(wěn)定性變得越來越重要。Sentinel 以流量為切入點,從流量控制、熔斷降級、系統(tǒng)負載保護等多個維度保護服務(wù)的穩(wěn)定性。

官網(wǎng):https://github.com/alibaba/Sentinel

中文官網(wǎng):https://github.com/alibaba/Sentinel/wiki

Sentinel與Hystrix的區(qū)別

由于Hystrix不再積極的開發(fā),進入維護階段,現(xiàn)在越來越多的開發(fā)者在項目中使用Spring Cloud Alibaba Sentinel組件。

Hystrix的關(guān)注點在于以 隔離和熔斷為主的容錯機制,超時或被熔斷的調(diào)用將會快速失敗,并可以提供 fallback 機制。

Sentinel的側(cè)重點在于:多樣化的流量控制、熔斷降級,系統(tǒng)負載保護,實時監(jiān)控和控制臺。

對比詳圖

 Sentinel的功能特點--摘自官方

Sentinel分為兩大部分:

核心庫(Java 客戶端)--自己的項目中的代碼。不依賴任何框架/庫,能夠運行于 Java 7 及以上的版本的運行時環(huán)境,同時對 Dubbo / Spring Cloud 等框架也有較好的支持。

控制臺(Dashboard)--控制臺主要負責管理推送規(guī)則、監(jiān)控、集群限流分配管理、機器發(fā)現(xiàn)等。

一、控制臺(Dashboard)

1、下載sentienl的jar包,本例使用:sentinel-dashboard-1.7.2.jar,地址:https://github.com/alibaba/Sentinel/releases

2、使用java -jar命令啟動Sentinel控制臺

啟動 Sentinel 控制臺需要 JDK 版本為 1.8 及以上版本。

3、訪問地址:http://localhost:8080/,8080為Sentinel的默認端口   默認賬號密碼為sentinel 

二、搭建客戶端

1.在自己的項目中引入依賴

<!---sentinel的依賴-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
    <version>2.2.1.RELEASE</version>
</dependency>

2.編輯項目中的 application.yml或者bootstrap.yml文件

添加Sentinel 控制臺配置信息

spring:
   cloud:
       sentinel:
          transport:
            port: 8719  # 應(yīng)用與Sentinel控制臺交互的端口,應(yīng)用本地會起一個該端口占用的HttpServer # 默認8719端口,假如端口被占用,依次+1,直到找到未被占用端口
            dashboard: localhost:8080 #sentinel控制臺的請求地址,需要啟動一個dashboard的jar

 3.資源是 Sentinel 中的一個關(guān)鍵概念。它可以是任何東西,例如服務(wù)、方法,甚至是代碼片段。

一旦被 Sentinel API 包裹,就被定義為資源,可以申請 Sentinel 提供的保護。

把需要控制流量的代碼用 Sentinel的關(guān)鍵代碼 SphU.entry("資源名") 和 entry.exit() 包圍起來即可。

實例代碼--摘自官方

    Entry entry = null;
    try {
        // 定義一個sentinel保護的資源,名稱為test-sentinel-api
        entry = SphU.entry(resourceName);
        // 模擬執(zhí)行被保護的業(yè)務(wù)邏輯耗時
        Thread.sleep(100);
        return a;
    } catch (BlockException e) {
        // 如果被保護的資源被限流或者降級了,就會拋出BlockException
        log.warn("資源被限流或降級了", e);
        return "資源被限流或降級了";
    } catch (InterruptedException e) {
        return "發(fā)生InterruptedException";
    } finally {
        if (entry != null) {
            entry.exit();
        }
 
        ContextUtil.exit();
    }
}

使用注解@SentinelResource 用于定義資源,并提供可選的異常處理和 fallback 配置項

value:資源名稱,必需項(不能為空)

entryType:entry 類型,可選項(默認為 EntryType.OUT)

blockHandler / blockHandlerClass: blockHandler 對應(yīng)處理 BlockException 的函數(shù)名稱,可選項

fallback:fallback 函數(shù)名稱,可選項,用于在拋出異常的時候提供 fallback 處理邏輯。

在項目中Controller中添加@SentinelResource(value = "Sentinel-name")

例如:

 啟動項目

三、查看接口的流量的詳情

1.實時監(jiān)控

2.簇點鏈路

3.等等:其他使用方法有待發(fā)掘 

補充:

1.QPS:每秒請求數(shù),當前調(diào)用該api的QPS到達閾值的時候進行限流

2.線程數(shù):當調(diào)用該api的線程數(shù)到達閾值的時候,進行限流

3.直接:當api大達到限流條件時,直接限流4

4.關(guān)聯(lián):當關(guān)聯(lián)的資源到達閾值,就限流自己

5.鏈路:只記錄指定路上的流量,指定資源從入口資源進來的流量,如果達到閾值,就進行限流,api級別的限流

6.熱點規(guī)則即經(jīng)常訪問的數(shù)據(jù)。很多時候我們希望統(tǒng)計某個熱點數(shù)據(jù)中訪問頻次最高的 Top K 數(shù)據(jù),并對其訪問進行限制。

7.響應(yīng)時間是指系統(tǒng)對請求作出響應(yīng)的時間。

8.吞吐量是指系統(tǒng)在單位時間內(nèi)處理請求的數(shù)量。

到此這篇關(guān)于Java之SpringCloudAlibaba Sentinel組件案例講解的文章就介紹到這了,更多相關(guān)Java之Sentinel組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • spring異步service中處理線程數(shù)限制詳解

    spring異步service中處理線程數(shù)限制詳解

    這篇文章主要給大家介紹了關(guān)于spring異步service中處理線程數(shù)限制的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用spring具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • vscode開發(fā)maven的javaweb項目并部署到tomcat及配置指南

    vscode開發(fā)maven的javaweb項目并部署到tomcat及配置指南

    這篇文章主要給大家介紹了關(guān)于vscode開發(fā)maven的javaweb項目并部署到tomcat及配置的相關(guān)資料,在vscode中創(chuàng)建maven項目,需要逐一操作下面的環(huán)節(jié),文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • Java修改maven的默認jdk版本為1.7的方法

    Java修改maven的默認jdk版本為1.7的方法

    這篇文章主要介紹了Java修改maven的默認jdk版本為1.7的方法,需要的朋友可以參考下
    2018-02-02
  • java 多態(tài)實例代碼

    java 多態(tài)實例代碼

    這篇文章主要介紹了java 多態(tài)實例代碼,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • SpringBoot 如何編寫配置文件

    SpringBoot 如何編寫配置文件

    這篇文章主要介紹了SpringBoot 編寫配置文件的兩種方法,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下
    2020-11-11
  • Java中Thread類的使用和它的屬性

    Java中Thread類的使用和它的屬性

    在java中可以進行多線程編程,在java標準庫中提供了一個Thread類,來表示線程操作,本文主要介紹了Java中Thread類的使用和它的屬性,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Java開發(fā)微信公眾號接收和被動回復(fù)普通消息

    Java開發(fā)微信公眾號接收和被動回復(fù)普通消息

    這篇文章主要介紹了Java開發(fā)微信公眾號接收和被動回復(fù)普通消息的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • Apache?Commons?Config管理配置文件核心功能使用

    Apache?Commons?Config管理配置文件核心功能使用

    這篇文章主要為大家介紹了Apache?Commons?Config管理和使用配置文件核心深入探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • 詳談Java中的事件監(jiān)聽機制

    詳談Java中的事件監(jiān)聽機制

    下面小編就為大家?guī)硪黄斦凧ava中的事件監(jiān)聽機制。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • java并發(fā)編程專題(八)----(JUC)實例講解CountDownLatch

    java并發(fā)編程專題(八)----(JUC)實例講解CountDownLatch

    這篇文章主要介紹了java CountDownLatch的相關(guān)資料,文中示例代碼非常詳細,幫助大家理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07

最新評論