您好,登錄后才能下訂單哦!
這篇文章主要介紹了Java @SentinelResource怎么應(yīng)用的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Java @SentinelResource怎么應(yīng)用文章都會有所收獲,下面我們一起來看看吧。
Module:cloudalibaba-sentinel-service8401
pom新增依賴
<dependency><!-- 引入自己定義的api通用包,可以使用Payment支付Entity --> <groupId>com.atguigu.springcloud</groupId> <artifactId>cloud-api-common</artifactId> <version>${project.version}</version> </dependency>
這個依賴來自自己的模板,這里的這個依賴就是去數(shù)據(jù)庫查詢的一部分業(yè)務(wù)處理
新增Controller
@RestController public class RateLimitController { @GetMapping("/byResource") @SentinelResource(value = "byResource",blockHandler = "handleException") public CommonResult byResource() { return new CommonResult(200,"按資源名稱限流測試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,就跑到我們自定義的處流,限流
測試1
1秒鐘點(diǎn)擊1下,OK
超過上述,瘋狂點(diǎn)擊,返回了自己定義的限流處理信息,限流發(fā)生
通過訪問的URL來限流,會返回Sentinel自帶默認(rèn)的限流處理信息
Controller修改為:
@RestController public class RateLimitController { @GetMapping("/byResource") @SentinelResource(value = "byResource",blockHandler = "handleException") public CommonResult byResource() { return new CommonResult(200,"按資源名稱限流測試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限流測試OK",new Payment(2020L,"serial002")); } }
測試2
訪問一次
http://localhost:8401/rateLimit/byUrl
正常
瘋狂點(diǎn)擊http://localhost:8401/rateLimit/byUrl
會返回Sentinel自帶的限流處理結(jié)果
上面兜底方案面臨的問題
1 系統(tǒng)默認(rèn)的,沒有體現(xiàn)我們自己的業(yè)務(wù)要求。
2 依照現(xiàn)有條件,我們自定義的處理方法又和業(yè)務(wù)代碼耦合在一塊,不直觀。
3 每個業(yè)務(wù)方法都添加一個兜底的,那代碼膨脹加劇。
4 全局統(tǒng)一的處理方法沒有體現(xiàn)。
創(chuàng)建CustomerBlockHandler類用于自定義限流處理邏輯
測試后我們自定義的出來了
控制類增加新的業(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)行兜底處理 定義通用的限流處理邏輯
測試3
測試后我們自定義的出來了
關(guān)于“Java @SentinelResource怎么應(yīng)用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“Java @SentinelResource怎么應(yīng)用”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。