溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Spring Cloud Alibaba中Sentinel怎么用

發(fā)布時(shí)間:2021-08-09 11:26:33 來源:億速云 閱讀:145 作者:小新 欄目:編程語言

這篇文章將為大家詳細(xì)講解有關(guān)Spring Cloud Alibaba中Sentinel怎么用,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

什么是Sentinel

Sentinel,中文翻譯為哨兵,是為微服務(wù)提供流量控制、熔斷降級(jí)的功能,它和Hystrix提供的功能一樣,可以有效的解決微服務(wù)調(diào)用產(chǎn)生的“雪崩”效應(yīng),為微服務(wù)系統(tǒng)提供了穩(wěn)定性的解決方案。隨著Hytrxi進(jìn)入了維護(hù)期,不再提供新功能,Sentinel是一個(gè)不錯(cuò)的替代方案。通常情況,Hystrix采用線程池對(duì)服務(wù)的調(diào)用進(jìn)行隔離,Sentinel才用了用戶線程對(duì)接口進(jìn)行隔離,二者相比,Hystrxi是服務(wù)級(jí)別的隔離,Sentinel提供了接口級(jí)別的隔離,Sentinel隔離級(jí)別更加精細(xì),另外Sentinel直接使用用戶線程進(jìn)行限制,相比Hystrix的線程池隔離,減少了線程切換的開銷。另外Sentinel的DashBoard提供了在線更改限流規(guī)則的配置,也更加的優(yōu)化。

從官方文檔的介紹,Sentinel 具有以下特征:

  • 豐富的應(yīng)用場景: Sentinel 承接了阿里巴巴近 10 年的雙十一大促流量的核心場景,例如秒殺(即突發(fā)流量控制在系統(tǒng)容量可以承受的范圍)、消息削峰填谷、實(shí)時(shí)熔斷下游不可用應(yīng)用等。

  • 完備的實(shí)時(shí)監(jiān)控: Sentinel 同時(shí)提供實(shí)時(shí)的監(jiān)控功能。您可以在控制臺(tái)中看到接入應(yīng)用的單臺(tái)機(jī)器秒級(jí)數(shù)據(jù),甚至 500 臺(tái)以下規(guī)模的集群的匯總運(yùn)行情況。

  • 廣泛的開源生態(tài): Sentinel 提供開箱即用的與其它開源框架/庫的整合模塊,例如與 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相應(yīng)的依賴并進(jìn)行簡單的配置即可快速地接入 Sentinel。

  • 完善的 SPI 擴(kuò)展點(diǎn): Sentinel 提供簡單易用、完善的 SPI 擴(kuò)展點(diǎn)。您可以通過實(shí)現(xiàn)擴(kuò)展點(diǎn),快速的定制邏輯。例如定制規(guī)則管理、適配數(shù)據(jù)源等。

如何在Spring Cloud中使用Sentinel

Sentinel作為Spring Cloud Alibaba的組件之一,在Spring Cloud項(xiàng)目中使用它非常的簡單?,F(xiàn)在以案例的形式來講解如何在Spring Cloud項(xiàng)目中使用Sentinel。本項(xiàng)目是在之前nacos教程的案例基礎(chǔ)上進(jìn)行改造。在工程的pom文件加上sentinel的Spring Cloud起步依賴,代碼如下:

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
  <version>0.9.0.RELEASE</version> 
</dependency>

在工程的配置文件application.yml文件中配置,需要新增2個(gè)配置:

  • spring.cloud.sentinel.transport.port: 8719 ,這個(gè)端口配置會(huì)在應(yīng)用對(duì)應(yīng)的機(jī)器上啟動(dòng)一個(gè) Http Server,該 Server 會(huì)與 Sentinel 控制臺(tái)做交互。比如 Sentinel 控制臺(tái)添加了1個(gè)限流規(guī)則,會(huì)把規(guī)則數(shù)據(jù) push 給這個(gè) Http Server 接收,Http Server 再將規(guī)則注冊(cè)到 Sentinel 中。

  • spring.cloud.sentinel.transport.dashboard: 8080,這個(gè)是Sentinel DashBoard的地址。

server:
 port: 8762
spring:
 application:
 name: nacos-provider
 cloud:
 nacos:
  discovery:
  server-addr: 127.0.0.1:8848
 sentinel:
  transport:
  port: 8719
  dashboard: localhost:8080

寫一個(gè)RestController,在接口上加上SentinelResource注解就可以了。

@RestController
public class ProviderController {

 @GetMapping("/hi")
 @SentinelResource(value="hi")
 public String hi(@RequestParam(value = "name",defaultValue = "forezp",required = false)String name){

  return "hi "+name;
 }

}

關(guān)于@SentinelResource 注解,有以下的屬性:

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

  • entryType:entry 類型,可選項(xiàng)(默認(rèn)為 EntryType.OUT)

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

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

啟動(dòng)Nacos,并啟動(dòng)nacos-provider項(xiàng)目。文末有源碼下載鏈接。

Sentinel DashBoard

Sentinel 控制臺(tái)提供一個(gè)輕量級(jí)的控制臺(tái),它提供機(jī)器發(fā)現(xiàn)、單機(jī)資源實(shí)時(shí)監(jiān)控、集群資源匯總,以及規(guī)則管理的功能.
Sentinel DashBoard下載地址:https://github.com/alibaba/Sentinel/releases

下載完成后,以以下的命令啟動(dòng)

java -jar sentinel-dashboard-1.6.1.jar

默認(rèn)啟動(dòng)端口為8080,可以-Dserver.port=8081的形式改變默認(rèn)端口。啟動(dòng)成功后,在瀏覽器上訪問localhost:8080,就可以顯示Sentinel的登陸界面,登陸名為sentinel,密碼為sentinel。

登陸sentinel dashboard成功后,并多次訪問nacos-provider的localhost:8080/hi接口,在nacos訪問信息如下:

Spring Cloud Alibaba中Sentinel怎么用

sentinel dashboard顯示了nacos-provider的接口資源信息。

Spring Cloud Alibaba中Sentinel怎么用

在/hi資源處設(shè)置接口的限流功能,在“+流控”按鈕點(diǎn)擊開設(shè)置界面如下,設(shè)置閾值類型為 qps,單機(jī)閾值為2。

Spring Cloud Alibaba中Sentinel怎么用

設(shè)置成功后可以在流控規(guī)則這一欄進(jìn)行查看,如圖所示:

Spring Cloud Alibaba中Sentinel怎么用

測(cè)試

多次快速訪問nacos-provider的接口資源http://localhost:8762/hi,可以發(fā)現(xiàn)偶爾出現(xiàn)以下的信息:

Blocked by Sentinel (flow limiting)

正常的返回邏輯為

hi forezp

由以上可只,接口資源/hi的限流規(guī)則起到了作用。

在FeignClient中使用Sentinel

Hystrix默認(rèn)集成在Spring Cloud 的Feign Client組件中,Sentinel也可以提供這樣的功能。現(xiàn)以案例的形式來講解如何在FeignClient中使用Sentinel,z本案例是在之前的nacos教程案例的nacos-consumer工程上進(jìn)行改造,除了引入spring-cloud-starter-alibaba-sentinel,還需要引入spring-cloud-starter-openfeign,代碼如下:

	<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-openfeign</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
			<version>0.9.0.RELEASE</version>
		</dependency>

在配置文件中需要加上sentinel.transport. dashboard配置外,還需要加上feign.sentinel.enabled的配置,代碼如下:

server:
 port: 8763
spring:
 application:
 name: nacos-consumer
 cloud:
 nacos:
  discovery:
  server-addr: 127.0.0.1:8848
 sentinel:
  transport:
  port: 8719
  dashboard: localhost:8080

feign.sentinel.enabled: true

寫一個(gè)FeignClient,調(diào)用nacos-provider的/hi接口:

@FeignClient("nacos-provider")
public interface ProviderClient {

 @GetMapping("/hi")
 String hi(@RequestParam(value = "name", defaultValue = "forezp", required = false) String name);
}

寫一個(gè)RestController調(diào)用ProviderClient,代碼如下:

@RestController
public class ConsumerController {

 @Autowired
 ProviderClient providerClient;
 
 @GetMapping("/hi-feign")
 public String hiFeign(){
  return providerClient.hi("feign");
 }
}

在FeignClient中,Sentinel為Feign調(diào)用生成了資源名策略定義,定義規(guī)則為httpmethod:protocol://requesturl。啟動(dòng)nacos-consumer工程,在Sentinel DashBoard生成了如下的資源信息:

Spring Cloud Alibaba中Sentinel怎么用

添加流控,QPS為2,在瀏覽器上快速多次點(diǎn)擊訪問http://localhost:8763/hi-feign,瀏覽器在正常情況下是能夠正常返回如下的信息:

hi feign

在被限流的時(shí)候返回錯(cuò)誤信息。

需要注意的是,被限流的時(shí)候FeignClient并不會(huì)調(diào)用nacos-provider的接口,而是在nacos-consumer工程里直接報(bào)錯(cuò)。

關(guān)于“Spring Cloud Alibaba中Sentinel怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI