當前位置:
首頁 >
前端技术
> 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; }}結果
成功
限流
其他
以上寫法可以給單個接口進行限流,如果想對所有接口限流,可以放在攔截器里。
如果使用Spring Cloud,可以在網(wǎng)關進行限流,例如zuul、gateway。不過站在業(yè)務角度來講,限流這個事還是微服務自己來處理更好一點——僅為個人觀點。
以Zuul為例,要引入“spring-cloud-zuul-ratelimit”的jar包,在配置文件中,可以進行全局限流,針對每個微服務進行單獨限流,也可以針對IP限流。
尤其是在一些對外平臺接口上,?限流就很重要了。
之前我所在公司就要開放幾個接口給客戶,一開始我們就提出了接口限流的事,但反饋的意見是會在合同里要求對方不能高頻調用?。
哪想到總是有不按合同辦事的客戶,一客戶竟然違規(guī)把接口倒手給第三方了,而第三方不知道限流這個事,就高頻次地調接口。業(yè)務初期,都覺得沒多少流量,所以服務器性能也弱,一下子給擠爆了?,緊急上的限流。
其實代碼沒多少,鬧出這等事,也是相當沒必要。
限流的四種方式:1固定窗口,2滑動窗口,3漏桶,4令牌桶,在接口限流的四種算法 中有介紹。
《新程序員》:云原生和全面數(shù)字化實踐50位技術專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的单个接口添加超时时间_SpringBoot使用Guava令牌桶对接口限流的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: springboot 整合mybatis
- 下一篇: python爬虫专家_Python爬虫入