當(dāng)前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
单个接口添加超时时间_SpringBoot使用Guava令牌桶对接口限流
生活随笔
收集整理的這篇文章主要介紹了
单个接口添加超时时间_SpringBoot使用Guava令牌桶对接口限流
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
pom.xml引入jar包
com.google.guava guava 29.0-jre代碼
@RestControllerpublic class HelloController { //創(chuàng)建令牌桶,每秒1個令牌 private RateLimiter rl = RateLimiter.create(1); @RequestMapping("/limit") public DefaultResult limit() { //獲取令牌,如果沒有則等待至超時,本代碼超時時間為0,立刻返回錯誤信息 boolean flag = rl.tryAcquire(0, TimeUnit.SECONDS); DefaultResult result = new DefaultResult(); if (!flag) { result.setCode(777); result.setMsg("限流"); } else { UserResult ur = new UserResult(); ur.setId(111); ur.setUserName("測試"); result.setData(ur); } return result; }}結(jié)果
成功
限流
其他
以上寫法可以給單個接口進行限流,如果想對所有接口限流,可以放在攔截器里。
如果使用Spring Cloud,可以在網(wǎng)關(guān)進行限流,例如zuul、gateway。不過站在業(yè)務(wù)角度來講,限流這個事還是微服務(wù)自己來處理更好一點——僅為個人觀點。
以Zuul為例,要引入“spring-cloud-zuul-ratelimit”的jar包,在配置文件中,可以進行全局限流,針對每個微服務(wù)進行單獨限流,也可以針對IP限流。
尤其是在一些對外平臺接口上,?限流就很重要了。
之前我所在公司就要開放幾個接口給客戶,一開始我們就提出了接口限流的事,但反饋的意見是會在合同里要求對方不能高頻調(diào)用?。
哪想到總是有不按合同辦事的客戶,一客戶竟然違規(guī)把接口倒手給第三方了,而第三方不知道限流這個事,就高頻次地調(diào)接口。業(yè)務(wù)初期,都覺得沒多少流量,所以服務(wù)器性能也弱,一下子給擠爆了?,緊急上的限流。
其實代碼沒多少,鬧出這等事,也是相當(dāng)沒必要。
限流的四種方式:1固定窗口,2滑動窗口,3漏桶,4令牌桶,在接口限流的四種算法 中有介紹。
《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的单个接口添加超时时间_SpringBoot使用Guava令牌桶对接口限流的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: springboot 整合mybatis
- 下一篇: java多图片上传json_Spring