在Linux下对Swagger进行限流,可通过以下方式实现:
-
Nginx限流
- 安装Nginx后,在配置文件中添加限流规则,例如:
http { limit_req_zone $binary_remote_addr zone=mylimit:10m rate=1r/s; } server { location /swagger/ { limit_req zone=mylimit burst=5 nodelay; proxy_pass http://localhost:8080; } }其中
rate=1r/s表示每秒1个请求,burst=5允许突发5个请求。 - 重启Nginx生效:
sudo systemctl restart nginx。
- 安装Nginx后,在配置文件中添加限流规则,例如:
-
Redis+Lua脚本限流
- 安装Redis和Lua模块,编写限流脚本(如控制每秒请求数),通过Nginx调用Lua脚本实现限流逻辑。
-
Spring Cloud Gateway限流(适用于微服务)
- 在
application.yml中配置限流规则:spring: cloud: gateway: routes: - id: swagger-route uri: http://localhost:8080 predicates: - Path=/api/** filters: - name: RequestRateLimiter args: key-resolver: "#{@ipKeyResolver}" redis-rate-limiter.replenishRate: 1 redis-rate-limiter.burstCapacity: 5需配合
KeyResolver定义限流键(如IP地址)。
- 在
说明:
- 以上方法需根据实际部署环境选择,Nginx适合反向代理场景,Spring Cloud Gateway适合微服务架构。
- 限流参数(如
rate、burst)需根据业务需求调整,避免过度限制影响正常访问。