边缘加速
  • 站点加速
    • 概述
    • 访问控制
      • Token authentication
        • Token 鉴权
        • 认证方法A
        • 认证方法B
        • 认证方法C
        • 认证方法D
        • 认证方法V
    • 智能加速
    • Cache configuration
      • 概述
      • EdgeOne caching rules introduction
        • EdgeOne 内容缓存规则
        • 缓存键(Cache Key)介绍
        • Vary 特性
      • 缓存配置
        • 自定义 Cache Key
        • 节点缓存 TTL
        • 状态码缓存 TTL
        • 浏览器缓存 TTL
        • 离线缓存
        • 缓存预刷新
      • 清除和预热缓存
        • 清除缓存
        • 预热缓存
        • Prefetch M3U8
      • How to improve the Cache Hit Rate of EdgeOne
    • 文件优化
      • 内容压缩
      • 智能压缩
    • 网络优化
      • HTTP/2
      • HTTP/3(QUIC)
        • 概述
        • 启用 HTTP/3
        • QUIC SDK
          • SDK 概览
          • SDK 下载和集成指引
          • 代码示例
            • Android
            • iOS
          • API 文档
            • Android
            • iOS
      • IPv6 访问
      • 最大上传大小
      • WebSocket
      • 携带客户端 IP 头部回源
      • 携带客户端 IP 地理位置头部回源
      • 开启 gRPC
      • Network Error Logging
    • URL 重写
      • 访问 URL 重定向
      • 回源 URL 重写
    • 修改头部
      • 修改 HTTP 节点响应头
      • 修改 HTTP 回源请求头
    • Modify response content
      • HTTP Response
      • Custom Error Page
    • 规则引擎
      • 概述
      • 规则管理
      • 变量
      • 规则引擎支持的匹配类型与操作
    • Image and video processing
      • Audio and Video Pre-pulling
      • Just-in-Time Image Processing
      • Video Just-In-Time Processing
      • VOD Media Origin
    • Speed limit for single connection download
    • 请求与响应行为
      • HTTP响应
      • 请求处理顺序
      • EdgeOne 默认 HTTP 回源请求头
      • EdgeOne 默认 HTTP 响应头
      • HTTP限制
    • 媒体服务
      • 音视频预拉取
      • 实时图片处理
      • 实时媒体处理
      • 点播媒体源
  • 四层代理
    • 概述
    • 新建四层代理实例
    • 修改四层代理实例配置
    • 停用/删除四层代理实例
    • 批量配置转发规则
    • 获取客户端真实IP
      • 通过 TOA 获取 TCP 协议客户端真实 IP
      • 通过 Proxy Protocol V1/V2 协议获取客户端真实 IP
        • 概述
        • 方式一:通过 Nginx 获取客户端真实 IP
        • 方式二:在业务服务器解析客户端真实 IP
        • Proxy Protocol V1/V2 获取的客户端真实 IP 格式
      • 通过 SPP 协议传递客户端真实 IP
  • 边缘 DNS
    • Domain Name Services
      • 概述
      • DNS resolution for managed domains
        • 修改 DNS 服务器
        • 配置域名 DNS 解析记录
        • 批量导入DNS记录
        • DNS 高级配置
      • Access accelerated domains
        • 添加加速域名
        • 站点/域名归属权验证
        • 修改 CNAME 解析
        • 验证业务访问
      • Traffic scheduling
        • 流量调度管理
    • HTTPS Certificate
      • Overview
      • Edge HTTPS Certificate
        • Overview
        • Deploying/Updating SSL Certificate for A Domain Name
        • Configuring A Free Certificate for A Domain Name
        • Using Keyless Certificate
      • Edge mTLS Authentication
      • Origin Certificate Validation
      • HTTPS configuration
        • Forced HTTPS Access
        • Enabling HSTS
        • SSL/TLS security configuration
          • Configuring SSL/TLS Security
          • TLS Versions and Cipher Suites
        • Enabling OCSP Stapling
      • Related References
        • Using OpenSSL to Generate Self-Signed Certificates
        • Certificate Format Requirements
        • The Difference Between one-way authentication and Mutual authentication
    • 源站配置
      • 负载均衡
        • 概述
        • 快速创建负载均衡实例
        • 健康检查策略介绍
        • 查看源站健康状态
        • 相关参考
          • 负载均衡相关概念
          • 请求重试策略介绍
      • Origin Group Configuration
      • 回源配置
        • 回源超时
        • 配置回源 HTTPS
        • Host Header 重写
        • 回源请求参数设置
        • 回源跟随重定向
        • HTTP/2 回源
        • 分片回源
        • Modify Origin
        • Origin-pull Rate Limiting Policy
      • Origin Protection(Obtaining/Updating Origin IP Address Range)
      • 相关参考
        • 旧版源站组兼容相关问题

Origin-pull Rate Limiting Policy

概述

当源站的性能有限时,如果用户请求突增,可能因为过高的 QPS 导致源站可能出现高负载或者故障,导致业务受损。针对该场景,EdgeOne 推出了回源限频功能,可支持用户自定义根据请求特征,限制用户请求回源的最大 QPS,针对超出限频的请求响应指定的状态码以及自定义响应页面,保护源站正常运行。
说明:
回源限频策略仅 EdgeOne 企业版套餐可用,默认每个站点最多可配置 5 条限频策略。

原理说明

EdgeOne 为用户提供了分布全球的边缘节点服务,用户的请求将通过不同地区的边缘节点回到源站,在请求回源时,EdgeOne 将通过定期采集所有边缘节点的回源请求量,然后根据用户所设定的回源限频值以及节点数量,按一定的比例自动分配各节点的可回源 QPS 数值,并且根据边缘节点的请求量变化动态调整,确保所有节点总计的回源请求量不会超出用户所限定的回源限频值。
说明:
由于数据采集及学习分配具有一定的延时,在首次配置回源限频 QPS 后,需要运行一段时间后才能趋于稳定。
回源限频策略基于边缘的访问请求特征进行统计、匹配并生效,如果您的源站是源站组、负载均衡,最终回源请求将继续按照源站组、负载均衡的权重及选路策略生效。




示例场景 1:限制动态 API 接口请求域名的回源总 QPS

当前域名 api.example.com 的源站为 1.1.1.1,该域名主要承载 API 接口动态业务,请求量很高,源站性能最高只能承载 10,000 QPS,为了保护源站,防护源站宕机,需要对回源的请求频率进行限制,对于触发限频的请求响应 512 状态码。操作步骤如下:
1. 登录 边缘安全加速平台 EO 控制台,在左侧菜单栏中,进入服务总览,单击网站安全加速内需配置的站点。
2. 在站点详情页面,单击回源限频策略。
3. 单击新建策略,在策略配置界面内,参考:回源限频策略配置项说明完善配置。按照当前示例场景配置,可选择匹配条件为 HOST 等于 api.example.com,配置限频值为 10,000 QPS,在响应状态码中,输入 512。参考配置如下:

4.点击保存,下发配置,等待域名部署完成后,限频策略即可生效。预期的生效结果是,如果客户端请求域名 api.example.com 的回源请求数不超过 10,000QPS,如果超出,则响应 512 状态码。

示例场景 2:根据不同的请求路径限制允许回源的总 QPS

当前域名 api.example.com 的源站为 1.1.1.1,有多个的对外接口服务,其中数据查询接口为 /data/Describedata;支付接口为 /pay/Orderpayment,数据查询接口仅允许最大 QPS 不超过 500,支付接口的最大查询接口不允许超过 1000,超出限频值时均响应 512 状态码。操作步骤如下:
1. 登录 边缘安全加速平台 EO 控制台,在左侧菜单栏中,进入服务总览,单击网站安全加速内需配置的站点。
2. 在站点详情页面,单击回源限频策略。
3. 单击新建策略,在策略配置界面内,参考:回源限频策略配置项说明完善配置。按照当前示例场景配置,先配置策略 1,可选择匹配条件为 HOST 等于 api.example.com AND URL path 等于 /data/Describedata,配置限频值为 500 QPS,在响应状态码中,输入 512。参考配置如下:



4. 点击保存,下发配置。然后重复以上步骤 3,新建一条策略 2,可选择匹配条件为 HOST 等于 api.example.com AND URL path 等于 /pay/Orderpayment,配置限频值为 500 QPS,在响应状态码中,输入 512。参考配置如下:



5. 以上策略均配置完成后,预期的生效结果是,如果客户端请求域名 api.example.com,请求路径为/data/Describedata 时,回源的请求 QPS 不允许超过 500 QPS,如果请求路径为 /pay/Orderpayment 时,回源的请求 QPS 不允许超过 1000 QPS,超出时均响应 512

相关参考

回源限频策略配置项说明

配置项
说明
策略名称
必填,可输入 1-255 个字符,字符不限。
描述
可选,可输入 0-1024 个字符,字符不限。
匹配条件
必填,匹配条件用于决定当前请求是否会触发回源限频规则,EdgeOne 将根据客户端发起的请求进行匹配,符合条件的请求将计入有效请求并在需要回源时根据限频值决定是否进行触发限频。
说明:
如果请求通过规则引擎、边缘函数等进行了回源改写,例如回源 URL 重写、修改回源请求头等,回源限频策略仍然是按照改写前的请求特征匹配。
支持的匹配条件包括:HOST、URL path、URL full、查询字符串、文件后缀、文件名称、HTTP 请求头、客户端地理位置、请求协议、客户端 IP、客户端运营商、请求方法、Cookie。
支持的匹配条件运算符、限制可参考:规则引擎支持的匹配类型与操作规则引擎配置字符限制
回源限频值
必填,可配置 10-1000000,用于限制最大的回源 QPS。
响应状态码
必填,在触发限频后,响应的状态码。支持配置 4XX、5XX,并且不可以配置为 499、514、509和 520-599。
自定义响应页面
可选,支持下拉选择当前已配置的自定义响应页面
与其他限频策略的关系
配置有多条回源限频策略的情况下,同一个请求可能匹配多个策略,限频的优先级从上往下逐条匹配来决定是否触发限频,您也可以根据下方的配置来决定当前请求是否终止匹配其它回源限频策略。
未触发限频时,继续匹配后续其它策略:如果后续还有其他的限频策略,未触发当前回源限频策略时,将继续匹配下方的限频策略,决定是否限频。
无论是否触发限频,不再匹配后续其它策略:请求匹配当前回源限频策略时,如果达到回源限频值则按照当前策略进行处置,如果未达到限频值,则可正常回源,不会继续匹配下方的策略。