本文为您介绍如何通过函数服务实现定时触发 CDN 刷新/预热任务。
对 CDN 节点进行刷新/预热,保证 CDN 缓存和源站内容的一致性,是 CDN 用户的常用操作。一些金融行业对变更时间有严格的要求,例如只允许每日凌晨进行变更。对于这种场景,手动进行刷新和预热操作繁琐且容易出错,通过函数服务定时触发刷新/预热任务,可以很好地解决用户诉求。
CDN:内容分发网络(Content Delivery Network,CDN)面向内容提供商,针对其在互联网上传播的图片、音视频、网页、下载包等静态内容,提供传输加速服务,优化用户访问体验,提高下载速度。更多介绍请参见 什么是内容分发网络。
刷新:在 CDN 节点上删除已经缓存的指定内容或将其标记为已过期。这样当用户下次访问节点获取内容时,节点将从源站拉取最新的内容,返回给用户并进行缓存。
预热:CDN 节点主动从源站拉取特定文件(一般是大文件,如视频文件、安装包文件等),并将文件缓存在节点上。这样当用户请求对应文件时,CDN 节点可以直接返回文件。该方式减少了节点从源站获取文件带来的延时,避免了用户同时请求大文件时源站下载压力过大。
内容分发网络
已开通内容分发网络。
已添加您的站点域名作为加速域名,具体操作可参见 新增域名。
已获取 API 访问密钥(AK 和 SK),并确保该密钥具有 CDN 缓存预热(SubmitPreloadTask)、缓存刷新(SubmitRefreshTask)的操作权限。具体操作可参见 Access Key(密钥)管理 和 创建用户并授权。
函数服务
日志服务
CDN 存在每日刷新/预热配额上限,执行当天如超过当日配额可能导致任务失败。详细内容可参见 刷新配额 和 预热配额。
使用 vefaas-golang-cdn-refresh-preload 代码模板创建函数,并将代码需要获取的 AK 和 SK 配置为环境变量。
登录 函数服务控制台。
在顶部导航栏,选择目标地域。
在函数列表页面,单击 创建函数。
在创建函数页面,选择 vefaas-golang-cdn-refresh-preload 模板,单击 下一步:函数配置。
按要求配置函数的信息。
配置项 | 说明 |
---|---|
日志功能 | 启用日志功能,投递至默认日志集。 |
环境变量 | 新增两条环境变量,将前提条件中准备的 AK 和 SK 配置为环境变量。配置格式为:
|
单击 确定,完成函数创建。
将函数的当前代码和配置发布至线上。
在函数详情页面,单击右上角的 发布。
函数版本 使用 Latest,按需填写 版本描述,实例数上限 保持默认。
单击 确定, 函数进入发布中。函数发布成功后如下图所示。
为当前函数配置 Timer 触发器,设置触发函数的规则。
切换至触发器页签,单击 创建触发器。
按要求配置触发器信息。
触发器类型:选择 Timer 触发器。
触发器名称:根据界面提示规则自定义触发器名称。
推送时间:根据业务需求设置触发周期和时间。本示例设置为每分钟触发。
立即启用:开启后,触发器才能正常工作。
请求并发:开启后,如果该触发器的上一个请求未完成,但下一个请求时间已到达时,将不等待上一请求完成,直接并发处理下一个请求。本示例不启用。
触发消息:通过触发消息向函数传递需要执行的任务类型(刷新/预热)和执行对象(URL)等信息。
说明
字段名 | 字段类型 | 是否必填 | 说明 |
---|---|---|---|
TaskKind | string | 是 | 任务类型。可选值有:
|
TaskType | string | 否 | 刷新任务类型,只有 TaskKind = refresh 才需填写。更多信息参见 CDN API 参考 Type 字段。
|
Urls | string | 是 | 指定一个或多个内容 URL。更多信息参见 CDN API 参考 Urls 字段。
|
ConcurrentLimit | int | 否 | 当 TaskKind = preload 时,指定内容分发网络在处理预热任务时,每次向源站请求的文件数量。更多信息参见 CDN API 参考 ConcurrentLimit 字段。 |
单击 确定,完成 Timer 触发器创建。
进入当前函数的 资源管理 页签。单击 日志,查看函数实例的实时日志,可看到已成功提交刷新/预热任务。
若启用日志功能,可进入当前函数的 日志 页签。查询当前函数的执行日志,可看到已成功提交刷新/预热任务。
进入 CDN 控制台的 刷新预热 页面,切换至 操作记录 页签,可查询刷新/预热任务是否执行成功,触发时间间隔是否符合预期。