国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

2021-11-04 21:23碼猿技術專欄不才陳某 Java教程

Spring Cloud Gateway本身自帶的限流實現,過濾器是RequestRateLimiterGatewayFilterFactory,不過這種上不了臺面的就不再介紹了,有興趣的可以實現下。

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

前一篇文章介紹了Spring Cloud Gateway的一些基礎知識點,今天陳某就來嘮一嘮網關層面如何做限流?

文章目錄如下:

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

網關如何限流?

Spring Cloud Gateway本身自帶的限流實現,過濾器是RequestRateLimiterGatewayFilterFactory,不過這種上不了臺面的就不再介紹了,有興趣的可以實現下。

今天的重點是集成阿里的Sentinel實現網關限流,sentinel有不懂的可以看陳某的文章:阿里限流神器Sentinel奪命連環 17 問?

從1.6.0版本開始,Sentinel提供了SpringCloud Gateway的適配模塊,可以提供兩種資源維度的限流:

  • route維度:即在配置文件中配置的路由條目,資源名為對應的routeId,這種屬于粗粒度的限流,一般是對某個微服務進行限流。
  • 自定義API維度:用戶可以利用Sentinel提供的API來自定義一些API分組,這種屬于細粒度的限流,針對某一類的uri進行匹配限流,可以跨多個微服務。

sentinel官方文檔:https://github.com/alibaba/Sentinel/wiki/%E7%BD%91%E5%85%B3%E9%99%90%E6%B5%81

Spring Cloud Gateway集成Sentinel實現很簡單,這就是阿里的魅力,提供簡單、易操作的工具,讓程序員專注于業務。

新建項目

新建一個gateway-sentinel9026模塊,添加如下依賴:

  1. --nacos注冊中心-->
  2. com.alibaba.cloud
  3. spring-cloud-starter-alibaba-nacos-discovery
  4.  
  5.  
  6. --springcloudgateway-->
  7. org.springframework.cloud
  8. spring-cloud-starter-gateway
  9.  
  10.  
  11. --springcloudgateway整合sentinel的依賴-->
  12. com.alibaba.cloud
  13. spring-cloud-alibaba-sentinel-gateway
  14.  
  15.  
  16. --sentinel的依賴-->
  17. com.alibaba.cloud
  18. spring-cloud-starter-alibaba-sentinel
  19.  

注意:這依然是一個網關服務,不要添加WEB的依賴

配置文件

配置文件中主要指定以下三種配置:

  • nacos的地址
  • sentinel控制臺的地址
  • 網關路由的配置

配置如下:

  1. spring:
  2. cloud:
  3. ##整合sentinel,配置sentinel控制臺的地址
  4. sentinel:
  5. transport:
  6. ##指定控制臺的地址,默認端口8080
  7. dashboard:localhost:8080
  8. nacos:
  9. ##注冊中心配置
  10. discovery:
  11. #nacos的服務地址,nacos-server中IP地址:端口號
  12. server-addr:127.0.0.1:8848
  13. gateway:
  14. ##路由
  15. routes:
  16. ##id只要唯一即可,名稱任意
  17. -id:gateway-provider
  18. uri:lb://gateway-provider
  19. ##配置斷言
  20. predicates:
  21. ##PathRoutePredicateFactory斷言,滿足/gateway/provider/**這個請求路徑的都會被路由到http://localhost:9024這個uri中
  22. -Path=/gateway/provider/**

上述配置中設置了一個路由gateway-provider,只要請求路徑滿足/gateway/provider/**都會被路由到gateway-provider這個服務中。

限流配置

經過上述兩個步驟其實已經整合好了Sentinel,此時訪問一下接口:http://localhost:9026/gateway/provider/port

然后在sentinel控制臺可以看到已經被監控了,監控的路由是gateway-provider,如下圖:

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

此時我們可以為其新增一個route維度的限流,如下圖:

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

上圖中對gateway-provider這個路由做出了限流,QPS閾值為1。

此時快速訪問:http://localhost:9026/gateway/provider/port,看到已經被限流了,如下圖:

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

以上route維度的限流已經配置成功,小伙伴可以自己照著上述步驟嘗試一下。

API分組限流也很簡單,首先需要定義一個分組,API管理-> 新增API分組,如下圖:

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

匹配模式選擇了精確匹配(還有前綴匹配,正則匹配),因此只有這個uri:http://xxxx/gateway/provider/port會被限流。

第二步需要對這個分組添加流控規則,流控規則->新增網關流控,如下圖:

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

API名稱那里選擇對應的分組即可,新增之后,限流規則就生效了。

陳某不再測試了,小伙伴自己動手測試一下吧...............

陳某這里只是簡單的配置一下,至于限流規則持久化一些內容請看陳某的Sentinel文章,這里就不再過多的介紹了。

如何自定義限流異常信息?

從上面的演示中可以看到默認的異常返回信息是:"Block.........",這種肯定是客戶端不能接受的,因此需要定制自己的異常返回信息。

下面介紹兩種不同的方式定制異常返回信息,開發中自己選擇其中一種。

直接配置文件中定制

開發者可以直接在配置文件中直接修改返回信息,配置如下:

  1. spring:
  2. cloud:
  3. ##整合sentinel,配置sentinel控制臺的地址
  4. sentinel:
  5. #配置限流之后,響應內容
  6. scg:
  7. fallback:
  8. ##兩種模式,一種是response返回文字提示信息,
  9. ##一種是redirect,重定向跳轉,需要同時配置redirect(跳轉的uri)
  10. mode:response
  11. ##響應的狀態
  12. response-status:200
  13. ##響應體
  14. response-body:'{"code":200,"message":"請求失敗,稍后重試!"}'

上述配置中mode配置的是response,一旦被限流了,將會返回JSON串。

  1. {
  2. "code":200,
  3. "message":"請求失敗,稍后重試!"
  4. }

重定向的配置如下:

  1. spring:
  2. cloud:
  3. ##整合sentinel,配置sentinel控制臺的地址
  4. sentinel:
  5. #配置限流之后,響應內容
  6. scg:
  7. fallback:
  8. ##兩種模式,一種是response返回文字提示信息,一種是redirect,重定向跳轉,需要同時配置redirect(跳轉的uri)
  9. mode:redirect
  10. ##跳轉的URL
  11. redirect:http://www.baidu.com

一旦被限流,將會直接跳轉到:http://www.baidu.com

編碼定制

這種就不太靈活了,通過硬編碼的方式,完整代碼如下:

  1. @Configuration
  2. publicclassGatewayConfig{
  3. /**
  4. *自定義限流處理器
  5. */
  6. @PostConstruct
  7. publicvoidinitBlockHandlers(){
  8. BlockRequestHandlerblockHandler=(serverWebExchange,throwable)->{
  9. Mapmap=newHashMap();
  10. map.put("code",200);
  11. map.put("message","請求失敗,稍后重試!");
  12. returnServerResponse.status(HttpStatus.OK)
  13. .contentType(MediaType.APPLICATION_JSON_UTF8)
  14. .body(BodyInserters.fromObject(map));
  15. };
  16. GatewayCallbackManager.setBlockHandler(blockHandler);
  17. }
  18. }

兩種方式介紹完了,根據業務需求自己選擇適合的方式,當然陳某更喜歡第一種,理由:約定>配置>編碼。

網關限流了,服務就安全了嗎?

很多人認為只要網關層面做了限流,躲在身后的服務就可以高枕無憂了,你是不是也有這種想法?

很顯然這種想法是錯誤的,復雜的微服務架構一個獨立服務不僅僅被一方調用,往往是多方調用,如下圖:

Spring Cloud Gateway 整合阿里 Sentinel 網關限流實戰

商品服務不僅僅被網關層調用,還被內部訂單服務調用,這時候僅僅在網關層限流,那么商品服務還安全嗎?

一旦大量的請求訂單服務,比如大促秒殺,商品服務不做限流會被瞬間擊垮。

因此需要根據公司業務場景對自己負責的服務也要進行限流兜底,最常見的方案:網關層集群限流+內部服務的單機限流兜底,這樣才能保證不被流量沖垮。

總結

文章介紹了Spring Cloud Gateway整合Sentinel對網關層進行限流,以及關于限流的一些思考。

原文鏈接:https://mp.weixin.qq.com/s/RK1mULrJvZSv9yGlZgYYTg

延伸 · 閱讀

精彩推薦
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
主站蜘蛛池模板: 精品国产一区二区三区在线观看 | 91黄在线观看 | 日本中文字幕在线 | 国产aaaaav久久久一区二区 | 天天天操| 特级a做爰全过程片 | 午夜网址| 九月激情网 | 黄色一级视频免费看 | 亚洲人成网亚洲欧洲无码 | 国产精品成av人在线视午夜片 | 国产精品无码久久久久 | 成人三区 | 一区二区不卡视频 | 日本a在线天堂 | 精品欧美一区二区三区久久久 | 久久精品国产亚卅av嘿嘿 | 日韩视频一区 | 91免费观看视频 | 一区二区三区国产好的精 | 日韩av免费在线观看 | 国产一区 | 精品一区久久 | 精品国产一区二区三区久久久蜜月 | 天天影视网色香欲综合网无拦截 | 九九久久免费 | 成人在线视频免费 | 久久99视频精品 | 91在线视频导航 | 欧美精品成人一区二区三区四区 | 91夜夜夜 | 偷拍自拍第一页 | 成人av电影网址 | 日韩免费视频一区二区 | 成人av网站在线观看 | 欧美一区在线看 | 99免费观看| av网站在线免费观看 | 欧美精品1区2区3区 欧洲一区在线 | 国产第一亚洲 | 精品成人在线视频 |