Java @SentinelResource全面介紹
按資源名稱限流加后續(xù)處理
Module:cloudalibaba-sentinel-service8401
pom新增依賴
<dependency><!-- 引入自己定義的api通用包,可以使用Payment支付Entity --> <groupId>com.atguigu.springcloud</groupId> <artifactId>cloud-api-common</artifactId> <version>${project.version}</version> </dependency>
這個(gè)依賴來(lái)自自己的模板,這里的這個(gè)依賴就是去數(shù)據(jù)庫(kù)查詢的一部分業(yè)務(wù)處理
新增Controller
@RestController public class RateLimitController { @GetMapping("/byResource") @SentinelResource(value = "byResource",blockHandler = "handleException") public CommonResult byResource() { return new CommonResult(200,"按資源名稱限流測(cè)試OK",new Payment(2020L,"serial001")); } public CommonResult handleException(BlockException exception) { return new CommonResult(444,exception.getClass().getCanonicalName()+"\t 服務(wù)不可用"); } }
圖形配置和代碼關(guān)系
表示1秒鐘內(nèi)查詢次數(shù)大于1,就跑到我們自定義的處流,限流
測(cè)試1
1秒鐘點(diǎn)擊1下,OK
超過(guò)上述,瘋狂點(diǎn)擊,返回了自己定義的限流處理信息,限流發(fā)生
額外問(wèn)題
此時(shí)關(guān)閉問(wèn)服務(wù)8401看看
Sentinel控制臺(tái),流控規(guī)則消失了?????
臨時(shí)/持久?
按照Url地址限流加后續(xù)處理
通過(guò)訪問(wèn)的URL來(lái)限流,會(huì)返回Sentinel自帶默認(rèn)的限流處理信息
Controller修改為:
@RestController public class RateLimitController { @GetMapping("/byResource") @SentinelResource(value = "byResource",blockHandler = "handleException") public CommonResult byResource() { return new CommonResult(200,"按資源名稱限流測(cè)試OK",new Payment(2020L,"serial001")); } public CommonResult handleException(BlockException exception) { return new CommonResult(444,exception.getClass().getCanonicalName()+"\t 服務(wù)不可用"); } @GetMapping("/rateLimit/byUrl") @SentinelResource(value = "byUrl") public CommonResult byUrl() { return new CommonResult(200,"按url限流測(cè)試OK",new Payment(2020L,"serial002")); } }
測(cè)試2
訪問(wèn)一次
http://localhost:8401/rateLimit/byUrl
正常
瘋狂點(diǎn)擊http://localhost:8401/rateLimit/byUrl
會(huì)返回Sentinel自帶的限流處理結(jié)果
上面兜底方案面臨的問(wèn)題
1 系統(tǒng)默認(rèn)的,沒(méi)有體現(xiàn)我們自己的業(yè)務(wù)要求。
2 依照現(xiàn)有條件,我們自定義的處理方法又和業(yè)務(wù)代碼耦合在一塊,不直觀。
3 每個(gè)業(yè)務(wù)方法都添加一個(gè)兜底的,那代碼膨脹加劇。
4 全局統(tǒng)一的處理方法沒(méi)有體現(xiàn)。
客戶自定義限流處理邏輯
創(chuàng)建CustomerBlockHandler類用于自定義限流處理邏輯
測(cè)試后我們自定義的出來(lái)了
控制類增加新的業(yè)務(wù)
@GetMapping("/rateLimit/customerBlockHandler") @SentinelResource(value = "customerBlockHandler", blockHandlerClass = CustomerBlockHandler.class, blockHandler = "handleException2") public CommonResult customerBlockHandler() { return new CommonResult(200,"按客戶自定義限流處理邏輯"); }
自定義通用的限流處理邏輯
blockHandlerClass = CustomerBlockHandler.class
blockHandler = handleException2
上述配置:找CustomerBlockHandler類里的handleException2方法進(jìn)行兜底處理 定義通用的限流處理邏輯
測(cè)試3
測(cè)試后我們自定義的出來(lái)了
到此這篇關(guān)于Java @SentinelResource全面介紹的文章就介紹到這了,更多相關(guān)Java @SentinelResource內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
FeignClientFactoryBean創(chuàng)建動(dòng)態(tài)代理詳細(xì)解讀
這篇文章主要介紹了FeignClientFactoryBean創(chuàng)建動(dòng)態(tài)代理詳細(xì)解讀,當(dāng)直接進(jìn)去注冊(cè)的方法中,一步步放下走,都是直接放bean的定義信息中放入值,然后轉(zhuǎn)成BeanDefinitionHolder,最后在注冊(cè)到IOC容器中,需要的朋友可以參考下2023-11-11Flink實(shí)現(xiàn)特定統(tǒng)計(jì)的歸約聚合reduce操作
這篇文章主要介紹了Flink實(shí)現(xiàn)特定統(tǒng)計(jì)的歸約聚合reduce操作,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-02-02生成8位隨機(jī)不重復(fù)的數(shù)字編號(hào)的方法
生成隨機(jī)不重復(fù)的數(shù)字編號(hào)在某些情況下也會(huì)用到,本文以生成8位隨機(jī)不重復(fù)的數(shù)字編號(hào)為例與大家分享下具體的實(shí)現(xiàn)過(guò)程,感興趣的朋友可以參考下2013-09-09tomcat connection-timeout連接超時(shí)源碼解析
這篇文章主要為大家介紹了tomcat connection-timeout連接超時(shí)源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11SpringBoot調(diào)用公共模塊的自定義注解失效的解決
這篇文章主要介紹了SpringBoot調(diào)用公共模塊的自定義注解失效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02Java獲取當(dāng)前操作系統(tǒng)的信息實(shí)例代碼
這篇文章主要介紹了Java獲取當(dāng)前操作系統(tǒng)的信息實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12