本文为您介绍如何通过函数服务实现 TOS 触发 CDN 刷新/预热任务。
互联网应用大多采用动静分离架构,将视频、音频、图片、JS 脚本等静态资源放在对象存储(TOS) 中,并使用 CDN 进行访问加速。若 TOS 的旧资源发生更新或升级,就需要及时更新节点已缓存内容,避免用户仍访问到旧的缓存资源。
CDN 提供刷新/预热功能,支持手动提交缓存刷新/预热任务。然而手动运维并不高效且容易出错,函数服务可以帮助您实现 TOS 变更自动触发 CDN 刷新/预热,极大地提高运维效率。
CDN:内容分发网络(Content Delivery Network,CDN)面向内容提供商,针对其在互联网上传播的图片、音视频、网页、下载包等静态内容,提供传输加速服务,优化用户访问体验,提高下载速度。更多介绍请参见 什么是内容分发网络。
刷新:在 CDN 节点上删除已经缓存的指定内容或将其标记为已过期。这样当用户下次访问节点获取内容时,节点将从源站拉取最新的内容,返回给用户并进行缓存。
预热:CDN 节点主动从源站拉取特定文件(一般是大文件,如视频文件、安装包文件等),并将文件缓存在节点上。这样当用户请求对应文件时,CDN 节点可以直接返回文件。该方式减少了节点从源站获取文件带来的延时,避免了用户同时请求大文件时源站下载压力过大。
内容分发网络
已开通火山引擎内容分发网络。
已添加您的站点域名作为加速域名,并将加速域名与您的 TOS Bucket 绑定(即将您的 TOS Bucket 作为加速域名的源站 ),具体操作可参见 使用 CDN 加速访问 TOS 资源。
已获取 API 访问密钥(AK 和 SK),并确保该密钥具有 CDN 缓存预热(SubmitPreloadTask)、缓存刷新(SubmitRefreshTask)的操作权限。具体操作可参见 Access Key(密钥)管理 和 创建用户并授权。
函数服务
日志服务
仅支持文件预热或文件刷新任务,暂不支持目录刷新任务。
一个函数仅能执行一种任务类型,无法同时执行文件预热和文件刷新任务。
使用 vefaas-golang-cdn-refresh-preload 代码模板创建函数,并将代码需要获取的 AK 和 SK 等信息配置为环境变量。
登录 函数服务控制台。
在顶部导航栏,选择目标地域。
在函数列表页面,单击 创建函数。
在创建函数页面,选择 vefaas-golang-cdn-refresh-preload 模板,单击 下一步:函数配置。
按要求配置函数的信息。
基础信息
配置函数名称和备注信息。
函数代码
代码模板已提供刷新/预热业务代码,无需配置。
高级配置
本示例仅配置日志功能和环境变量,其余参数保持默认配置。
配置项 | 说明 |
---|---|
日志功能 | 启用日志功能,投递至默认日志集。 |
环境变量 | 需新增以下 4 条环境变量:
示例:
|
单击 确定,完成函数创建。
将函数的当前代码和配置发布至线上。
在函数详情页面,单击右上角的 发布。
函数版本 使用 Latest,按需填写 版本描述,实例数上限 保持默认。
单击 确定, 函数进入发布中。函数发布成功后如下图所示。
为当前函数配置 TOS 触发器,设置触发函数的规则。
切换至触发器页签,单击 创建触发器。
按要求配置触发器信息。更多参数介绍请参见 创建 TOS 触发器。
单击 确定,完成 TOS 触发器创建。
控制台验证
在当前函数的触发器页签下,选择刚才创建的 TOS 触发器,单击 Bucket 名称,跳转至对象存储控制台的对应 Bucket。单击 上传文件,从本地提交一个文件。
返回函数服务控制台,进入当前函数的资源管理页签。单击 日志,查看函数实例的实时日志,可看到已成功提交刷新/预热任务。
若启用日志功能,可进入当前函数的 日志 页签。查询当前函数的执行日志,可看到已成功提交刷新/预热任务。
进入 CDN 控制台的 刷新预热 页面,切换至 操作记录 页签,可查询刷新/预热任务是否执行成功。
业务验证
说明
您可通过响应头中的 X-Bdcdn-Cache-Status
字段判断是否命中 CDN 缓存。
X-Bdcdn-Cache-Status: TCP_HIT
表示命中。X-Bdcdn-Cache-Status: TCP_MISS
表示未命中。