- 最新动态
- 功能总览
- 服务公告
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
- 最佳实践
- API参考
- SDK参考
- 场景代码示例
-
常见问题
-
功能咨询
- 什么是全站加速(WSA)?
- CDN支持哪些业务类型?
- CDN支持中国大陆境外或全球加速吗?
- CDN支持DNS,HTTPDNS,IP302这三种调度方式吗?
- CDN支持哪些协议?
- CDN点播加速支持HLS和RTMP协议吗?
- CDN能否区分用户使用电脑端还是手机端访问?
- CDN支持针对网站单个页面加速吗?
- CDN是否支持二进制文件加速?
- CDN支持二级域名加速么?
- CDN是否可以对网站的Post请求进行加速?
- CDN是否支持直播加速?
- CDN有速度限制吗?
- CDN能否加速本地访问购物网站的速度从而抢购商品?
- CDN支持哪些源站类型?
- 华为云CDN是否支持对中文域名的加速?
- 华为云CDN是否支持HTTP3.0?
- 华为云CDN是否支持对内容进行加密后再分发给用户?
- 华为云CDN支持内网加速吗?
- 华为云CDN可以提供所有的节点IP地址和回源IP地址吗?
- 是否支持CDN域名配置从现有账号迁移至华为云另一个账号?
- 加速静态和动态资源的原理是否一样?
- 如何停止CDN业务
- CDN上传文件有没有大小限制?
- CDN是否支持频次控制?
- CDN支持实时监控功能吗?
- CDN是否支持绑定HOST等固定IP访问的方式来提供服务?
-
使用咨询
- 如何通过项目来管控分配CDN的使用权限?
- 如何对IAM子账号开放CDN部分权限?
- CDN域名服务范围对源站服务器位置、备案是否有要求?
- CDN服务范围仅选择中国大陆或中国大陆境外,未加速区域的用户访问时会怎样?
- CDN是否支持部分地区加速,部分地区不加速?
- CDN流量和带宽的进制换算规则是什么?
- CDN是对网站所在的服务器加速,还是对域名加速?
- CDN支持添加泛域名作为加速域名吗?
- 中国大陆、中国大陆境外、全球服务范围的CDN加速之间有什么区别?
- 国外IP地址访问加速域名时,会通过哪个节点加速?
- 服务器在中国大陆境外,网站访问人群在中国大陆,该如何选择服务范围?
- 业务集中在一个城市,是否有必要使用CDN?
- 华为云CDN如何判断用户所属地区?
- 从其它服务商迁移CDN到华为云要怎么做?CDN如何切流?
- 同一个加速域名是否可以加速多个源站域名?
- 配置CDN后能否加速文件上传速度?
- 能否实现国内用户直接访问源站服务器,而国外用户接入CDN加速?
- 源站端口使用的自定义端口而非80端口,能否使用CDN?
- 源站在国内或者国外,可以直接使用全球加速吗?
- 源站为其他云服务厂商(非华为云)的对象存储桶,如何在CDN接入源站?
- 加速域名是否支持对指定线路的访问用户进行CDN加速?
- 加速域名备案过期了有什么影响?
- 加速域名和源站域名有什么区别?
- 接入CDN的加速域名和源站域名需要备案吗?
- 同一个加速域名下面有不同类型的内容(网站、视频点播、文件下载),能使用CDN进行加速吗?
- 开通了“企业项目”后,子账号调用接口时报错“无法获取domain id”
- CDN可以和直播加速共用域名吗?
-
购买计费
- CDN在哪些环节收费,如何收费?
- CDN受到恶意攻击会计费吗?
- CDN流量包相关问题汇总
- CDN是否可以看到单个加速域名的计费情况?
- CDN是否会对HTTP/HTTPS请求数计费?
- CDN从OBS拉取的流量是什么流量?
- 如何设置流量包剩余使用量预警?
- 如何设置余额预警阈值?
- 如何核对每月的CDN月结95带宽峰值计费情况?
- 为什么流量包中的流量使用量与统计分析中的流量显示存在差别?
- 为什么购买了流量包,还会扣除余额?
- 点播加速和文件下载加速收费一样吗?
- 什么是保留期?
- 配置全球加速后中国大陆和中国大陆境外所消耗的流量、带宽是否分开计费?
- 因欠费导致CDN服务不可用的情况排查
- 使用OBS桶作为源站且已购买OBS回源流量包,但CDN产生的回源流量未从OBS回源流量包中扣除
-
域名配置
- CDN是否支持配置带端口的加速域名?
- CDN加速域名可以用子域名吗?
- CDN加速域名的CNAME是否可以直接访问?
- CDN添加安全证书后,源站还需要配置证书吗?
- 审核未通过的域名还可以再修改吗?
- 多个加速域名是否可以使用同一源站IP地址?
- 使用OBS桶作为源站接入CDN加速,OBS域名能否作为加速域名?
- 网站服务在国内如何设置加速网站域名?
- 接入CDN的域名能否根据QPS(每秒请求数)进行限流?
- 华为云CDN是否支持加速经过VPN跳转的资源?
- 使用华为云CDN加速,域名解析是否必须在华为云?
- 同一个CDN加速域名能否同时支持国内和海外?
- 已经停用域名,更换域名解析,为什么访问加速域名还是会到CDN节点?
- 如果加速域名是泛域名,如何配置证书?
- HTTPS证书配置提交时提示“证书链不齐全”,如何进行证书链补齐?
- HTTPS证书配置提交时提示“证书格式不对”,如何进行PEM证书格式转换?
- HTTPS配置是否支持添加自签名证书?
- 开启HTTPS强制跳转后,为什么在浏览器内访问正常,但是通过api请求HTTP会导致post请求丢失参数?
- 配置HTTPS后还可以使用HTTP访问吗?
- 已接入CDN的加速域名备案过期怎么办?
-
缓存配置
- CDN节点的缓存多久会更新,会自动更新吗?
- CDN是否支持正则表达式设置缓存策略?
- CDN是否支持批量配置加速域名的缓存策略?
- CDN会缓存 404、403状态码吗?
- CDN有哪些默认的缓存配置?是否有效?
- 为什么全站加速域名的缓存命中率大于0?
- CDN缓存配置下目录路径指浏览器地址中的路径,还是服务器中文件的路径?
- 为什么CDN的缓存命中率较低?
- 为什么OBS桶删除了文件之后,用户还能通过CDN地址访问下载该文件?
- 如何设置缓存首页(根目录)?
- 如何判断CDN是否缓存命中?
- 在CDN控制台资源缓存过期时间设置为0,为何访问到的仍然不是最新内容?
- 华为云CDN是否支持octet-stream流文件的缓存?
- 缓存配置中配置缓存过期时间为365天,未过期,为什么有些文件能下载有些不能?
- 网站资源不需要缓存,需要直接从源站获取,该如何设置?
- 缓存可以指定目录,以及指定文件后缀吗?
- 域名被盗链,更换域名会影响之前的缓存吗?
- 资源全部预热,缓存过期时间为1年,为什么最近统计到回源流量?
- 如何保证CDN的内容和源站同步?
- 缓存配置为什么没有生效?
-
故障相关
- 域名未在华为云上接入过CDN,系统提示该域名已添加
- 配置HTTPS安全加速后,为什么访问加速域名不成功?
- 从CDN获取到的数据是旧的,没有更新缓存
- 访问CDN加速后的资源,返回状态码304
- 使用OBS私有桶做源站,创建授权委托失败
- 修改源站IP地址后,访问网页无法正常显示
- 访问失败,报Access-Control-Allow-Origin错误
- 添加CDN加速后,百度蜘蛛为什么抓取失败?
- 为什么OBS桶接入CDN后,访问域名会列出所有文件列表?
- 为什么CDN配置好以后,视频播放卡顿?
- 为什么CDN被禁用了?
- 为什么域名配置HTTPS后页面一直提示301?
- 为什么配置CDN加速后,ping加速域名出现超时?
- 配置CDN加速后,回源获取的资源不正确
- 配置CDN后,为什么首次访问很慢?
- 配置了CDN加速,为什么中国大陆境外无法访问?
- 使用CDN加速OBS桶文件后访问变成强制下载
- 域名添加失败怎么办?
- 刷新预热
- 安全相关
- 统计日志
- 回源相关
- 配额相关
-
功能咨询
- 故障排除
- WSA用户指南
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
配置远程鉴权
华为云CDN支持远程鉴权功能,即:当用户向CDN节点请求资源时,CDN将用户请求转发到您指定的鉴权服务器,CDN根据鉴权服务器返回的结果判断是否给用户返回资源。
背景信息
远程鉴权功能类似URL鉴权,区别如下:
- URL鉴权:鉴权由CDN节点完成。
- 远程鉴权:CDN节点转发用户请求到您指定的鉴权服务器,由鉴权服务器完成鉴权功能。
远程鉴权用户请求流程如下:

步骤 |
说明 |
---|---|
① |
用户携带鉴权参数访问CDN节点。 |
② |
CDN将用户请求转发至远程鉴权服务器。 |
③ |
远程鉴权服务器完成鉴权操作,给CDN节点返回响应状态码。 |
④ |
CDN节点根据接收到的状态码判断是否给用户返回所请求的资源。 |
注意事项
- 远程鉴权功能默认关闭。
- 后台有特殊配置的域名,暂不支持使用远程鉴权功能。
操作步骤
- 登录华为云控制台,在控制台首页中选择“CDN与智能边缘 > 内容分发网络 CDN”,进入CDN控制台。
- 在左侧菜单栏中,选择“域名管理”。
- 在域名列表中,单击需要修改的域名或域名所在行的“设置”,进入域名配置页面。
- 选择“访问控制”页签,单击“远程鉴权配置”后的“编辑”,进入配置弹窗。
图2 配置远程鉴权
表2 参数说明 参数
说明
示例
鉴权服务器地址
可访问的服务器地址。
- 输入的URL必须带有“http”或“https”。
- 不能是localhost或127.0.0.1这类本地地址。
- 不能是CDN的加速域名。
- 远程鉴权服务器默认为80/443端口,如需修改,请提交工单申请。
https://example.com/auth
请求方法
鉴权服务器支持的请求方法,支持GET、POST、HEAD。
GET
鉴权文件类型
- 所有文件类型:所有文件均参与鉴权。
- 指定文件后缀:指定类型的文件参与鉴权,多个后缀用“|”分隔,示例:jpg|MP4。
- 支持数字0-9、字符a-z、A-Z,且字符总数不超过512。
- 文件类型不区分大小写,即:jpg和JPG代表同一种文件类型。
所有文件类型
保留参数设置
设置用户请求中需要参与鉴权的参数,可选保留所有URL参数、忽略所有URL参数、保留指定URL参数。
- 参数填写规范:不区分大小写,多个参数用“|”分隔。
保留所有URL参数
自定义URL参数
设置CDN节点转发用户请求到远程鉴权服务器时需添加的参数。您可以选择预设参数或自定义参数(参数值不区分大小写)。
- 自定义:不支持变量,采用字符串形式下发。
- 选择参数:选择预设的参数或自定义参数,取值支持配置变量。
选择参数:http_host
取值:$http_host
保留请求头设置
设置用户请求中参与鉴权请求头,可选保留所有请求头参数、保留指定请求头参数、忽略所有请求头参数。
参数填写规范:不区分大小写,多个参数用“|”分隔。
保留所有请求头参数
自定义请求头参数
设置CDN节点转发用户请求到远程鉴权服务器时需要添加的请求头,可以选择系统预设的请求头,也可以自定义请求头(参数值不区分大小写)。
- 自定义:不支持变量,采用字符串形式下发。
- 选择参数:选择预设的参数或自定义参数,取值支持配置预设变量。
选择参数:http_referer
取值:$http_referer
鉴权成功状态码
设置鉴权成功时远程鉴权服务器返回给CDN节点的状态码。
- 取值范围:2xx/3xx。
200
鉴权失败状态码
设置鉴权失败时远程鉴权服务器返回给CDN节点的状态码。
- 取值范围:4xx/5xx。
403
响应自定义状态码
设置鉴权失败时CDN节点返回给用户的状态码。
- 取值范围:2xx/3xx/4xx/5xx。
403
鉴权超时时间
设置从CDN转发鉴权请求开始,到CDN节点收到远程鉴权服务器返回的结果为止的时间。单位为毫秒,值为0或50~3000。
60
鉴权超时之后的动作
设置鉴权超时后,CDN节点如何处理用户请求。
- 通过:鉴权超时后允许用户请求,返回对应的资源。
- 拒绝:鉴权超时后拒绝用户请求,返回配置的响应自定义状态码给用户。
拒绝
表3 预设参数 变量名
变量含义
说明
$http_host
请求头中的Host值。
只有客户端请求携带这些值时才可以获取到。
$http_user_agent
请求头中的User-Agent值。
$http_referer
请求头中的Referer值。
$http_x_forwarded_for
请求头中的X-Forwarded-For值。
$http_content_type
请求头中的Content-Type值。
$remote_addr
请求的Client IP信息。
-
$scheme
请求的协议类型。
-
$server_protocol
请求的协议版本。
-
$request_uri
uri+'?'+args的内容。
-
$uri
请求的原始URI。
-
$args
请求的query string,不包含'?'。
-
$request_method
请求方法。
-
- 根据参数提示填写相关参数,单击“确定”完成配置。
- (可选)关闭远程鉴权配置。
- 关闭“状态”开关即可关闭远程鉴权配置,此时所有配置将被清空,下次启用远程鉴权功能时需要重新配置相关参数。
配置示例
域名example.com开启了远程鉴权,配置请见图3。
- 客户端原始请求URL:https://example.com/folder01/test.txt?key=***,原始请求中携带Header:test=123。
- CDN转发给远程鉴权服务器的URL为:GET https://192.168.9.1/remoteauth?key=***,CDN转发给远程鉴权服务器的请求包含header:test=123。
- 可能的鉴权结果:
- 结果1:鉴权成功,CDN节点与用户开始正常的缓存数据访问交互。
- 结果2:鉴权失败,CDN节点返回403状态码给用户。
- 结果3:鉴权超时,CDN节点执行鉴权超时动作,放行用户请求。