AI写作智能体 自主规划任务,支持联网查询和网页读取,多模态高效创作各类分析报告、商业计划、营销方案、教学内容等。 广告
如果说我们之前讲的所有限流策略都是进行接口级别的限流,那么系统自适应的限流是从服务运行的**整体角度进行应用级别的入口的流量限制**。 ## 一、系统规则 系统保护规则是从应用级别的入口流量进行控制,从单台机器的 load、CPU 使用率、平均 RT、入口 QPS 和并发线程数等几个维度监控应用指标,让系统尽可能跑在最大吞吐量的同时保证系统整体的稳定性。 系统保护规则是应用整体维度的,而不是资源维度的,并且**仅对入口流量生效**。入口流量指的是进入应用的流量(`EntryType.IN`),比如 Web 服务或 Dubbo 服务端接收的请求,都属于入口流量。 系统规则支持以下的模式: ![](https://img.kancloud.cn/b2/af/b2af19a52d31d192bdf0e889fdf96010_812x285.png) * **Load 自适应**(仅对 Linux/Unix-like 机器生效):系统的 load1 作为启发指标,进行自适应系统保护。当系统 load1 超过设定的启发值,且系统当前的并发线程数超过估算的系统容量时才会触发系统保护(BBR 阶段)。系统容量由系统的`maxQps * minRt`估算得出。设定参考值一般是`CPU cores * 2.5`。 * **CPU usage**(1.5.0+ 版本):当系统 CPU 使用率超过阈值即触发系统保护(取值范围 0.0-1.0),比较灵敏。 * **平均 RT**:当单台机器上所有入口流量的平均 RT 达到阈值即触发系统保护,单位是毫秒。 * **并发线程数**:当单台机器上所有入口流量的并发线程数达到阈值即触发系统保护。 * **入口 QPS**:当单台机器上所有入口流量的 QPS 达到阈值即触发系统保护。 > 注意:以上的系统规则,只有Load负载是自适应的,其他的都是达到阈值后触发系统保护。建议使用Load负载自适应! ## 二、如何查看linux系统的运行信息 我们要进行服务自适应的规则配置**阈值**,我们在平时服务运行的时候就要知道它的**正常值**。 * 怎么查看服务运行主机的当前Load负载?w命令 ![](https://img.kancloud.cn/e2/39/e2398ef02662e76712e8b9ff8f38d4a0_853x96.png) * 怎么查看服务运行主机的当前CPU使用率?htop命令 ![](https://img.kancloud.cn/40/39/40394c8b7d1d59c82c6db1c18750cc36_1276x85.png) * 怎么查看当前服务运行的平均RT和QPS?通过sentinel的“实时监控” ![](https://img.kancloud.cn/41/2c/412c75e37b9aca4e8b22cee10b4ddcb6_1508x356.png) ![](https://img.kancloud.cn/32/6e/326eec0bc8127001c826cc6e19c817ea_1538x433.png) * 怎么查看当前服务运行的并发线程数量? ~~~ ps -Lf <服务进程ID>|wc -l ~~~