Java研学-SpringCloud(十)
五 流控规则
1 介绍
Sentinel 流控规则通过限制超出系统处理能力的多余请求(如设置 QPS 阈值或并发线程数),防止资源耗尽(如 CPU 过载、线程池满、数据库连接池枯竭),从而保障系统在高并发或异常流量下的稳定性和可用性。
在 Sentinel 中,流控模式(直接、关联、链路)的配置仅适用于快速失败(Reject)策略,而其他策略(如匀速排队、Warm Up)不支持这些流控模式的设置
2 规则设置
QPS每秒请求数 底层使用计数器统计数量 轻量速度快
并发线程数效果与QPS相同 需配合线程池 统计线程池中的线程数量 性能较低(线程切换,调用等)
单机均摊为1,表示在集群环境下,每个服务实例(节点)独立分配的请求处理配额为1个/秒。例如,当集群部署5个服务实例时,理论最大处理能力为5个请求/秒(1×5)。
总体阈值为1,表示整个集群所有实例的总请求处理上限为1个/秒,即无论集群规模如何扩展,系统每秒仅允许处理1个请求,超出部分将触发限流策略。
3 流控规则 – 高级选项
① 直接策略:
高级选项中,直接策略(默认方案)表示直接对资源进行限制,QPS超出阈值,就会丢弃
② 链路策略:
指根据链路,对不同调用方,设置不同的调用限制,如A,B都要调用C,但C设置链路规则,A可以无限制调用C资源,但B每秒钟只可以调用2次 – OrderController
@RestController
public class OrderController {@AutowiredOrderService orderService;// 所需属性@AutowiredOrderProperties orderProperties;@GetMapping("/config")public String config(){return "order.timeout:"+orderProperties.getTimeOut()+ ";order.autoconfirm:"+orderProperties.getAutoConfirm()+ ";order.dbUrl:"+orderProperties.getDbUrl();}@GetMapping("/create")public Order createOrder(@RequestParam("productId") Long productId,@RequestParam("userId") Long userId) {Order order = orderService.createOrder(productId, userId);return order;}// 与 createOrder 相同也会调用远程资源@GetMapping("/createB")public Order createOrderB(@RequestParam("productId") Long productId,@RequestParam("userId") Long userId) {Order order = orderService.createOrder(productId, userId);// 设置id作为区分