【利用无服务器云函数(SCF)】自动刷新COS中变更文件的CDN!

简单几步,利用Serverless,让COS中文件变更自动刷新CDN!

背景

这几天遇到这样的一个场景,相信也是大多数的站长会遇到的一个问题:

自己的一个个人站点使用了COS作为前端静态资源的存储(JS、CSS、图片等等),同时开启了CDN作为资源的加速分发,为了最大的达到加速效果,把这些资源的缓存时间设置30天及以上。某一天,自己的站点需要变更一下css样式,修改完之后扔到COS中,发现站点中的样式仍没有生效。最后想起是命中了CDN的缓存,因此需要到 CDN控制台 进行URL刷新。

现状

目前COS(对象存储)控制台是没有提供这样一个功能:当启用了CDN,COS中文件变更时(上传、删除)自动去刷新CDN的选项。

分析

马云说:世界是由懒人创造的。

上面提到的刷新的工作,一次还好,但每次更新站点的静态文件都需要去执行这样的操作,这样重复性的功能是一定要得到解决的,谁让我懒…

想了下,COS文件变更的场景分为 2 种:

  • API上传
  • GUI上传(控制台、COS Browser…)

要实现自动刷新CDN,则需要用到CDN的 刷新URL的API

API上传

如果你是在代码里去上传静态资源的,那么你是能够知道文件上传的时刻的,在文件传完后去调用CDN的API则完成工作。

但是,如果你也同时通过COS控制台来上传文件,那这样的场景则覆盖不了,因此这种做法并不全面。在此也不做多的描述了。

GUI上传

首先,会遇到一个难题,COS本身没有提供设置文件更变之后的回调的功能,如果能拿到这个的回调,则不管是通过什么方式的上传,均能被覆盖到。

既然写了这篇东西,也不卖关子了,直接介绍下我们的主角:SCF(无服务器云函数),简单说,SCF能实现事件式的触发,让你的一段代码跑在云上,无需自己去搭建服务器。而这里我们要利用他很重要的一个能力:COS文件上传/删除的触发器。

下面我们就一步步来实现我们要的功能:

注意: 地域需要选择与COS中存放静态资源的Bucket同个地域的,这里以我广州的 Bucket 为例,创建广州的函数

起个名字叫 cdn_refresh, 环境的话,我选择 Nodejs(这里推荐大家选 Nodejs 就行,因为我的这段demo是用的node,你需要使用的话,不懂node也没关系,改一下配置就行)

  • 2、修改 demo 配置

下载我这个 demo的代码,解压后修改里面的几个配置信息,包括secretId、secretKey、以及你的cdn域名

把写好的代码压缩成 zip 包,通过本地上传 zip 包选项传上去,执行方法不用修改

  • 3、添加触发方式,完成创建

选择 COS 触发,Bucket选择静态资源存储的bucket,事件类型我们选择文件上传,点击保存,完成函数创建

  • 4、再次添加文件删除的触发方式,完成配置

上面我们支持了文件上传的触发方式,这里再添加上文件删除的触发,这样才是完整的文件变更

测试效果

以上,我们就完成了 SCF 侧函数的配置,那下面我们直接看效果就行

我在控制台上传了文件 nba.jpg

我们在 SCF 控制台能看到调用相关的日志

最后,因为 CDN刷新是异步刷新,我们可以去 CDN控制台 查看刷新记录

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Jackson0714

【Discuz】关闭QQ互联插件提示信息:系统繁忙,请稍后再试

31211
来自专栏jojo的技术小屋

转 入门Webpack,看这篇就够了

2017年8月13日更新,本文依旧最新的webpack3.5.3将代码部分完全重写,所有代码都在Mac上正常运行过。希望依旧对你学习webpack有帮助。 ...

34710
来自专栏云服务试衣间

简单几步,利用Serverless,让COS中文件变更自动刷新CDN

SCF能实现事件式的触发,让你的一段代码跑在云上,无需自己去搭建服务器。而这里我们要利用能力:COS文件上传/删除的触发器。

6.2K29
来自专栏Petrichor的专栏

Adblock:简单强大的广告过滤沙盒

  之前在使用浏览器时,经常会为太多弹窗广告所困。后来师兄教我说可以用一个叫做 AddBlock 的沙盒来过滤掉广告,遂自己上网查阅了相关资料。后来发现一个特别...

902
来自专栏农夫安全

如何移除Android应用广告

0x00 前言 我用以前做过的一个小游戏为例,源代码地址:http://git.oschina.net/androidsourcecode/parity,如果不...

3976
来自专栏深度学习之tensorflow实战篇

CRT /Linux基本设置的语言颜色问题设置

 远程连接unix系统的工具,以前用的最多的就是SSH了,不过SSH有一个硬伤,不能设置客户端编码,有时候看中文很容易乱码,而且不能分组记录多服务器地址。put...

38210
来自专栏mukekeheart的iOS之旅

iOS学习——iOS项目Project 和 Targets配置详解

  最近开始学习完整iOS项目的开发流程和思路,在实际的项目开发过程中,我们通常需要对项目代码和资料进行版本控制和管理,一般比较常用的SVN或者Github进行...

3967
来自专栏一场梦

年龄计算PHP源码

805
来自专栏未闻Code

在全新的Ubuntu中安装Python3 环境

在全新的Ubuntu 18.04中已经自带了Python 3。但是这个Python环境并不完整,需要补充安装下面几个模块。

994
来自专栏沈唁志

怎么使用WordPress小工具添加新浪微博秀、一键关注等按钮

怎么使用WordPress小工具添加新浪微博秀、一键关注等按钮?其实这个也不算什么稀奇了,就是直接使用新浪微博的微博组件

761

扫码关注云+社区