SpringBoot接口限流的實(shí)現(xiàn)方法小結(jié)
API限流是一種重要的策略,用于控制對(duì)API的訪問速率,以保護(hù)后端服務(wù)免受過載和濫用。以下是API限流的必要性:
- 防止服務(wù)過載:
當(dāng)API的請(qǐng)求量突然激增時(shí),如果沒有限流措施,可能會(huì)導(dǎo)致服務(wù)器資源耗盡,從而影響服務(wù)的穩(wěn)定性和可用性。 - 提高系統(tǒng)穩(wěn)定性:
通過限制每個(gè)用戶的請(qǐng)求頻率,可以確保系統(tǒng)在高負(fù)載下仍能正常運(yùn)行,避免因單個(gè)用戶或服務(wù)的過度請(qǐng)求而導(dǎo)致的系統(tǒng)崩潰。 - 防止惡意攻擊:
限流可以作為一種安全措施,防止惡意用戶通過發(fā)起大量請(qǐng)求來攻擊系統(tǒng),如DDoS攻擊或暴力 破解嘗試。
在 Spring Boot 中,可以通過多種方式實(shí)現(xiàn)接口限流。
以下是幾種常用的實(shí)現(xiàn)方法:
1. 使用 Bucket4j
Bucket4j 是一個(gè) Java 的限流庫,可以很容易地集成到 Spring Boot 項(xiàng)目中。
步驟:
添加 Maven 依賴:
<!-- https://mvnrepository.com/artifact/com.bucket4j/bucket4j-core --> <dependency> <groupId>com.bucket4j</groupId> <artifactId>bucket4j-core</artifactId> <version>8.10.1</version> </dependency>
創(chuàng)建限流配置:
import net.jodah.bucket4j.Bucket; import net.jodah.bucket4j.BucketBuilder; import java.time.Duration; @Service public class RateLimiterService { private final Bucket bucket; public RateLimiterService() { this.bucket = Bucket.builder() .addLimit(BucketLimit.of(10, Duration.ofMinutes(1))) .build(); } public boolean tryConsume() { return bucket.tryConsume(1); } }
在控制器中使用限流:
@RestController public class MyController { private final RateLimiterService rateLimiterService; @Autowired public MyController(RateLimiterService rateLimiterService) { this.rateLimiterService = rateLimiterService; } @GetMapping("/api") public ResponseEntity<String> api() { if (!rateLimiterService.tryConsume()) { return ResponseEntity.status(HttpStatus.TOO_MANY_REQUESTS).body("請(qǐng)求過于頻繁,請(qǐng)稍后再試。"); } return ResponseEntity.ok("請(qǐng)求成功!"); } }
2. 使用 Spring Cloud Gateway
如果你使用 Spring Cloud Gateway,可以在配置文件中設(shè)置限流規(guī)則。
示例配置:
spring: cloud: gateway: routes: - id: my_route uri: lb://my-service predicates: - Path=/api/** filters: - requestRateLimiter: rateLimiter: refillPolicy: tokens: 10 duration: 1s burstCapacity: 20
3. 使用 AOP 方式
通過 AOP(面向切面編程)也可以實(shí)現(xiàn)限流。
步驟:
創(chuàng)建注解:
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface RateLimit { int limit() default 10; // 限制次數(shù) int timeout() default 60; // 超時(shí)時(shí)間 }
使用 AOP 切面:
@Aspect @Component public class RateLimitAspect { // 實(shí)現(xiàn)限流邏輯 @Around("@annotation(rateLimit)") public Object limit(ProceedingJoinPoint joinPoint, RateLimit rateLimit) throws Throwable { // 限流邏輯 return joinPoint.proceed(); } }
在需要限流的控制器方法上使用:
@RestController public class MyController { @RateLimit(limit = 10, timeout = 60) @GetMapping("/api") public ResponseEntity<String> api() { return ResponseEntity.ok("請(qǐng)求成功!"); } }
4. 集成第三方庫Resilience4j:
Resilience4j
是一個(gè)輕量級(jí)的容錯(cuò)庫,它提供了多種限流器實(shí)現(xiàn),如SemaphoreBasedRateLimiter
。- 添加
Resilience4j
依賴后,可以配置限流器,并在控制器中使用注解@RateLimiter
進(jìn)行限流。
5.使用分布式鎖實(shí)現(xiàn)限流:
- 在某些情況下,可以使用分布式鎖(如Redisson)來實(shí)現(xiàn)限流,尤其是在需要防止用戶重復(fù)操作的場景中。
結(jié)論
以上是常用的幾種限流實(shí)現(xiàn)方式,可以根據(jù)項(xiàng)目需求選擇適合的方法。
選擇哪種限流方案取決于具體的業(yè)務(wù)需求和系統(tǒng)架構(gòu)。對(duì)于分布式系統(tǒng),通常推薦使用Redis或第三方庫如Resilience4j來實(shí)現(xiàn)限流,以保證限流的準(zhǔn)確性和一致性。而對(duì)于單機(jī)應(yīng)用,Guava RateLimiter或Spring Boot Actuator的@RateLimiter注解可能是更簡單的選擇。
到此這篇關(guān)于SpringBoot接口限流的實(shí)現(xiàn)方法小結(jié)的文章就介紹到這了,更多相關(guān)SpringBoot接口限流內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis resultmap 如何為對(duì)象賦值的調(diào)用順序
這篇文章主要介紹了mybatis resultmap 如何為對(duì)象賦值的調(diào)用順序,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01SpringBoot應(yīng)用剛啟動(dòng)時(shí)服務(wù)報(bào)大量超時(shí)的問題及解決
在Java項(xiàng)目上線過程中,經(jīng)常遇到的超時(shí)問題主要是由于JVM的JIT編譯導(dǎo)致,JIT(Just-In-Time)編譯是Java虛擬機(jī)的一項(xiàng)技術(shù),用于提高Java應(yīng)用的性能,它通過將熱點(diǎn)代碼(頻繁執(zhí)行的部分)轉(zhuǎn)換成本地機(jī)器碼來優(yōu)化執(zhí)行效率2024-11-11玩轉(zhuǎn)SpringBoot2快速整合攔截器的方法
這篇文章主要介紹了玩轉(zhuǎn)SpringBoot2快速整合攔截器的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09spring-boot-starter-thymeleaf加載外部html文件方式
本文介紹了在SpringMVC中使用Thymeleaf模板引擎加載外部HTML文件的方法,以及在Spring Boot中使用Thymeleaf的基本步驟,包括引入依賴、創(chuàng)建Controller、創(chuàng)建HTML文件、參數(shù)化訪問、熱加載和熱更新文件2025-02-02Java中讀寫鎖ReadWriteLock的原理與應(yīng)用詳解
Java并發(fā)編程提供了讀寫鎖,主要用于讀多寫少的場景,今天我們就重點(diǎn)來講解讀寫鎖ReadWriteLock的原理與應(yīng)用場景,感興趣的可以了解一下2022-09-09如何使用IntelliJ IDEA搭建MyBatis-Plus框架并連接MySQL數(shù)據(jù)庫
這篇文章主要介紹了如何使用IntelliJ IDEA搭建MyBatis-Plus框架并連接MySQL數(shù)據(jù)庫,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11IDEA-Maven項(xiàng)目的jdk版本設(shè)置方法
我們需要設(shè)置jdk的版本,不然會(huì)提示導(dǎo)致語法錯(cuò)誤,這篇文章主要介紹了IDEA-Maven項(xiàng)目的jdk版本設(shè)置方法,小編覺得不錯(cuò),一起來了解一下2019-04-04MyBatis實(shí)現(xiàn)動(dòng)態(tài)查詢、模糊查詢功能
這篇文章主要介紹了MyBatis實(shí)現(xiàn)動(dòng)態(tài)查詢、模糊查詢功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06