您可以配置CDN节点中某个或某些缓存资源的缓存过期时间规则。当CDN节点缓存的资源达到设置的缓存过期时间后,用户再次请求该资源时,CDN将直接回源站请求对应的最新资源返回给用户,并缓存到CDN节点。支持按照“首页”、“所有文件”、“目录路径”、“文件名后缀”及“全路径”方式指定资源范围,同时支持针对不同的缓存规则配置“URL参数”,从而提高缓存命中率,提升分发效率。
背景信息
CDN节点的缓存策略遵循HTTP标准协议,通过HTTP响应头中的Cache-control: max-age的字段来设置CDN节点上数据的缓存时间。添加缓存规则让CDN用户可以对指定的业务做定制化的数据缓存时间管理。合理的配置缓存时间,能够有效的提升命中率,降低回源率,节省用户的带宽。
当用户向CDN节点请求数据时,CDN节点会判断缓存数据是否过期。如果缓存数据未过期,则直接将缓存数据返回给用户,提升获取速度;否则,CDN节点就会向源站发出回源请求,从源站请求最新数据,更新本地缓存,并将最新数据返回给用户。
注意事项
- 每个域名最多可添加60条缓存规则。
- CDN缓存过期时间会对“回源率”产生直接的影响。如果CDN缓存过期时间过短,CDN节点上的数据会经常失效,导致频繁回源,增加了源站的负载,同时也增大了访问延时;如果CDN缓存过期时间过长,会带来数据更新时间慢的问题。
- 缓存过期时间设置为0时,该文件的所有请求都将回源,可能存在加速业务中断的风险。
- 节点缓存的资源,可能会由于热度较低而被提前从CDN节点删除。
- 如果您修改了缓存规则,请注意:
- 新的规则仅对后面缓存的资源生效,已经缓存的资源需要等缓存过期后,再次缓存才会遵循新的缓存规则。
- 如果您想要新的规则对所有资源(包括节点已缓存资源)立即生效,请在修改缓存规则后执行缓存刷新操作。
操作步骤
- 登录华为云控制台,在控制台首页中选择“ CDN与智能边缘 > 内容分发网络 CDN”,进入CDN控制台。
- 在左侧菜单栏中,选择。
- 在域名列表中,单击需要修改的域名或域名所在行的“设置”,进入域名配置页面。
- 选择“缓存配置”页签。
- 在缓存规则模块,单击“编辑”,系统弹出“配置缓存策略”对话框。
- 单击“添加”,根据业务需求配置缓存策略,如图1所示。具体配置参数说明如表1所示,您还可以单击“查看缓存策略配置建议”查看推荐的配置。
图1 配置缓存策略
表1 缓存策略配置参数
参数 |
说明 |
配置规则 |
所有文件 |
设置CDN节点所有缓存资源的过期时间。 |
对于新添加的加速域名,CDN默认添加一条“所有文件”缓存过期时间为30天的规则(全站加速默认缓存时间为0),此默认规则允许修改,不允许删除。 |
文件名后缀 |
设置指定文件类型的缓存资源的缓存规则。
对于新添加的业务类型为网站加速、文件下载加速和点播加速,且源站为“源站IP”或“源站域名”的加速域名,CDN默认添加一条常规动态文件(如.php .jsp .asp .aspx)缓存过期时间为0的规则,对此类动态文件请求会直接回源。此默认规则允许修改和删除。 |
- 支持所有格式的文件类型。
- 输入首字符为“.”,以“;”进行分隔。
- 输入的文件后缀名总数不能超过100个。
- 字符总数不能超过1000。
- 文件名后缀英文字符支持大写和小写。
示例:.JPG;.zip;.exe。
说明:
如果您的域名在后台有特殊配置,支持的文件后缀总数不能超过20,总字符数不能超过255。
|
目录路径 |
设置某一指定路径下的缓存资源的缓存规则。 |
前缀匹配,输入要求以“/”作为首字符,以“;”进行分隔,输入的目录路径总数不能超过20个,且字符总数不能超过255。示例:/test/folder01;/test/folder02。
- 支持通配符匹配,使用通配符时要注意以下规则:
- 使用通配符匹配时每条规则只能配置一个*,且只能输入一个目录路径如:/test/*。
- 前缀匹配,如果配置路径为/test/*,则/test/abc、/test/abc/001都会遵循该条缓存规则。
- 后台有特殊配置的域名,不支持配置通配符*。
- 通配符*不能匹配“/”,如/test/*/abc不能匹配到 /test/folder01/folder02/abc。
- 通配符只能匹配一个或多个字符,例:/test*不能匹配到/test。
- 不可配置/*。
|
全路径 |
设置完整路径下某一文件的缓存规则。 |
输入要求以“/”作为首字符,"*"不能在结尾。支持匹配指定目录下的具体文件或者带通配符"*"的文件。单条全路径缓存规则里仅支持配置一个全路径。
示例:如/test/index.html或/test/*.jpg |
缓存首页 |
设置根目录缓存规则 |
网站的根目录就是网站的顶层文件目录,目录下放着网站所有的子文件夹。
|
优先级 |
缓存规则的优先级。
优先级设置具有唯一性,不支持多条缓存规则设置同一优先级,且优先级不能输入为空。多条缓存规则下,不同缓存规则中的相同资源内容,CDN按照优先级高的缓存规则执行缓存内容过期。 |
取值为1~100之间的整数,数值越大优先级越高。 |
缓存过期时间 |
达到设置的缓存过期时间后,当用户向CDN节点请求资源时,CDN会直接回源站请求对应的最新资源返回给用户,并缓存到CDN节点中。 |
时间设置不能超过365天,建议参考如下规则进行配置:
- 对于不经常更新的静态文件(如.jpg、.zip等),建议将缓存过期时间设置成1个月以上。
- 对于频繁更新的静态文件(如js、css等),请根据实际业务情况设定。
- 对于动态文件(如php、jsp、asp、动态接口等),建议设置成0秒,回源获取。
|
URL参数 |
目前大多数的网页请求都携带URL参数信息,参数以“?”开始,如果参数没有包含重要信息(如版本信息等),可以设置忽略部分参数,从而提高缓存命中率,提升分发效率。
配置原则:
- URL参数变化,资源不变,可以配置忽略参数。
- URL参数变化,资源变化,不可配置忽略参数。
- 如果您开通了“视频拖拽”功能,请将您视频资源对应的“URL参数”设置为“忽略参数”。
|
- 不忽略参数:不忽略“?”之后的参数。
- 忽略参数:忽略所有URL参数,CDN缓存时忽略请求URL中“?”之后的参数,提高缓存命中率。
- 忽略指定参数:CDN缓存时将忽略您在控制台配置的参数,保留其它参数。
- 保留指定参数:CDN缓存时将保留您在控制台配置的参数,忽略其它参数。
|
URL参数值 |
需要忽略或保留的指定参数值,当“URL参数”选择“不忽略参数”或“忽略参数”时不填。 |
- 最多可填写10个参数名,多个参数之间用“;”分隔。
- 支持数字0-9、字符a-z、A-Z,及特殊符"."、"_"、"~"。
|
缓存过期时间来源,即原缓存遵循源站配置。 |
如果源站配置了缓存过期时间,即源配置了Cache-Control:max-age或Expires,您希望CDN的缓存过期时间与源站配置一致,或者取缓存规则配置的过期时间与源站的最小值,可以通过配置缓存过期时间来源实现。默认缓存过期时间来源为CDN,支持配置的取值如下:
- 源站:CDN节点的缓存过期时间遵循源站的设置。
- CDN:CDN节点的缓存过期时间遵循“缓存规则”中的“缓存过期时间”。
- 源站和CDN的最小值:CDN节点的缓存过期时间取缓存规则和源站二者的最小值。
说明:
- 如果源站同时配置了Cache-Control和Expires,优先遵从Cache-Control配置的过期时间。
- 如果“缓存过期时间来源”为“源站”,但是源站没有配置Cache-Control和Expires,此时节点缓存遵循CDN配置的缓存规则。
|
缓存过期时间来源默认为CDN。 |
强制缓存 |
CDN节点缓存过期时间是否忽略源站响应头Cache-Control中的no-cache、private、no-store字段,开启代表忽略,关闭代表不忽略。强制缓存与缓存过期时间来源功能配合使用,配合使用规则如下:
- 缓存过期时间来源配置为“源站”,强制缓存功能关闭。
- 此时如果源站响应头Cache-Control设置了no-cache、private、no-store,CDN节点将不缓存资源。
- 如果源站设置了其他响应头,缓存优先级为s-maxage->max-age->expires。例如源站同时设置了Cache-Control:max-age=500 , s-maxage=400,此时CDN节点的缓存过期时间遵循s-maxage的值400s。
- 如果源站没有设置以上响应头,执行CDN控制台配置的缓存过期时间。
- 缓存过期时间来源配置为“源站”,强制缓存功能开启。
- 如果源站响应头设置了缓存过期时间,缓存优先级为s-maxage->max-age->expires。例如源站同时设置了Cache-Control:max-age=500 , s-maxage=400,此时CDN节点的缓存过期时间遵循s-maxage的值400s。
- 如果源站没有设置以上响应头,执行CDN控制台配置的缓存过期时间。
- 缓存过期时间来源配置为“CDN”,强制缓存功能开启。
- 此时忽略源站响应头,执行CDN控制台配置的缓存过期时间。
- 缓存过期时间来源配置为“CDN”,强制缓存功能关闭。
- 如果源站响应头Cache-Control设置了no-cache、private、no-store,CDN节点将不缓存资源。
- 如果源站响应头Cache-Control未设置no-cache、private、no-store,执行CDN控制台配置的缓存过期时间。
- 缓存过期时间来源配置为“源站和CDN的最小值”,强制缓存功能关闭。
- 如果最小值为CDN节点设置的缓存过期时间,则与4规则一致。
- 如果最小值为源站设置的缓存时间,则与1一致。
- 缓存过期时间来源配置为“源站和CDN的最小值”,强制缓存功能开启。
- 如果最小值为CDN节点设置的缓存过期时间,则与3规则一致。
- 如果最小值为源站设置的缓存时间,则与2一致。
|
默认开启强制缓存功能。 |
- (可选)通过单击缓存规则所在行的“删除”,删除不需要的缓存规则。
- 单击“确定”,完成缓存规则配置。
配置示例
配置场景1:某客户的域名“www.example.com”配置了CDN加速,缓存规则配置见下图。
配置结果:网站首页不缓存,所有页面均不会忽略URL参数。
配置场景2:设置某个类型的文件不缓存
- 某客户的域名“www.example.com”配置了CDN加速,由于业务需求,需要对“.do”格式的文件不缓存,同时所有文件都忽略URL参数。
需要在CDN控制台增加一条文件名后缀为“.do”的缓存规则,缓存过期时间设置为“0”。
新规则仅对后续资源缓存生效,新规则配置完成后,建议您刷新“.do”文件所在的URL或者目录,新规则才可以对所有“.do”文件生效。
- 某客户配置了CDN加速,发现登录界面无限循环,无法登录,停用CDN加速后,可以正常登录。
这是因为CDN节点缓存了登录界面导致的,需要在控制台增加一条针对登录界面的缓存规则,缓存过期时间设置为“0”。以华为云控制台登录界面为例,华为云控制台的登录页面为“https://auth.huaweicloud.com/authui/login.html#/login”,在控制台增加一条全路径:/authui/login.html#/login,缓存过期时间为“0”的缓存规则。
配置场景3:某客户加速域名www.example.com设置了如下图的缓存规则,不知道哪一个规则生效。
用户访问www.example.com/test/cdn.jpg,虽然所有文件、文件名后缀、全路径三条规则都匹配到了,但是由于全路径的优先级为8,在三条规则里优先级最高,所以系统最终匹配全路径/test/*.jpg这条规则。