這篇“Java @SentinelResource實例代碼分析”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Java @SentinelResource實例代碼分析”文章吧。
Module:cloudalibaba-sentinel-service8401
pom新增依賴
<dependency><!-- 引入自己定義的api通用包,可以使用Payment支付Entity -->
<groupId>com.atguigu.springcloud</groupId>
<artifactId>cloud-api-common</artifactId>
<version>${project.version}</version>
</dependency>這個依賴來自自己的模板,這里的這個依賴就是去數據庫查詢的一部分業務處理
新增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 服務不可用");
}
}
圖形配置和代碼關系

表示1秒鐘內查詢次數大于1,就跑到我們自定義的處流,限流
測試1
1秒鐘點擊1下,OK
超過上述,瘋狂點擊,返回了自己定義的限流處理信息,限流發生

通過訪問的URL來限流,會返回Sentinel自帶默認的限流處理信息
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 服務不可用");
}
@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
正常

瘋狂點擊http://localhost:8401/rateLimit/byUrl

會返回Sentinel自帶的限流處理結果
上面兜底方案面臨的問題
1 系統默認的,沒有體現我們自己的業務要求。
2 依照現有條件,我們自定義的處理方法又和業務代碼耦合在一塊,不直觀。
3 每個業務方法都添加一個兜底的,那代碼膨脹加劇。
4 全局統一的處理方法沒有體現。
創建CustomerBlockHandler類用于自定義限流處理邏輯
測試后我們自定義的出來了
控制類增加新的業務
@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方法進行兜底處理 定義通用的限流處理邏輯
測試3


測試后我們自定義的出來了

以上就是關于“Java @SentinelResource實例代碼分析”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。