通过 Cloudflare 和 jsDelivr 免费加速博客 GitHub 图床等静态资源
通过 Cloudflare 和 jsDelivr 免费加速博客 GitHub 静态资源(GitHub图床),自动实现 CDN 资源的海内外分流,加速博客访问速度。
1 前言
上一篇文章讲述了如何使用 PicGo + GitHub 搭建图床,这样搭建的图床很稳定,但缺点是国内访问速度慢。可以使用 jsDelivr
对 Github 图床等静态资源进行免费 CDN 加速
使用PicGo + GitHub 搭建 Obsidian 图床
jsDelivr
是国外的一家优秀的公共 CDN 服务提供商,该平台是首个「打通中国大陆与海外的免费 CDN 服务」,无须担心中国防火墙问题而影响使用。官网:http://www.jsdelivr.com/(opens new window)但是jsDelivr
因为掉 ICP 等原因,国内速度越来越慢。好在 Chinajsdelivr 项目将它在国内“复活”了。
因此,本文思路是,对于 Github 公开仓库中的静态资源:
- 如果访问来源是国内,则使用 Chinajsdelivr 进行加速,域名为
jsd.cdn.zzko.cn
- 如果访问来源是国内,则使用原版 jsDelivr 进行加速,域名为
cdn.jsDelivr.net
即:
|
|
也就是说,我希望对于同一个资源链接,能够根据国内外请求来源自动重定向,使用不同的 CDN 加速链接。这就可以使用 Cloudflare 的重定向规则。
2 Cloudflare
2.1 配置域名
使用 Cloudflare 托管域名,这一点教程很多,跟着做就行,
在 DNS 配置中,新增一条 CNAME 解析记录,并启用代理。
如图,我这里是将 cdn.haoyep.com
解析到了 jsd.cdn.zzko.cn
,并使用 Cloudflare 代理(点亮小云朵)。
2.2 配置重定向规则
目标:资源链接都使用 cdn.haoyep.com
,Cloudflare 在代理 cdn.haoyep.com
时,判断请求来源是国内,则将 cdn.haoyep.com
重定向到 jsd.cdn.zzko.cn
;国外的请求则重定向到 cdn.jsdelivr.net
。
- 配置国内重定向
- 规则名称 (必需):标注国内,方便区分
- 自定义筛选表达式:
(http.host eq "cdn.haoyep.com" and ip.geoip.country eq "CN")
- URL 重定向
- 类型:动态
- 表达式:
concat("https://jsd.cdn.zzko.cn", http.request.uri.path)
- 状态代码:
302
- 配置国外重定向
- 规则名称 (必需):标注国外,方便区分
- 自定义筛选表达式:
(http.host eq "cdn.haoyep.com" and ip.geoip.country ne "CN")
- URL 重定向
- 类型:动态
- 表达式:
concat("https://cdn.jsdelivr.net", http.request.uri.path)
- 状态代码:
302
提示
HTTP 重定向状态选择302而不是301。虽然两类请求都会被 Cloudflare 缓存,但301理论上是永久跳转而302是临时跳转,因此301可能会导致长时间缓存,不利于今后修改重定向到新地址。
3 PicGo 设置
为了让上传的图片自动生成 CDN 链接,还需要配置 PicGo:
- 设定存储路径:可以不填,也可以填仓库的某个文件夹
- 自定义域名: 改为
https://<cdn加速链接>/gh/<用户名>/<图床仓库名>
,如图我这里改成https://cdn.haoyep.com/gh/leegical/Blog_img
即可。
对于之前文章中的 Github raw 或文件链接,替换成 CDN 链接即可。本文只需要进行以下替换:
|
|
4 参考文章
Chinajsdelivr简介 利用 Cloudflare 重定向规则实现 CDN 资源的海内外分流 使用npm加速静态资源相关内容
- 使用PicGo + GitHub 搭建 Obsidian 图床
- Windows 下使用 Hugo 和 Cloudflare Pages 配置博客
- 使用 vercel 加速 Github 图床
- 通过Cloudflare tunnel访问内网端口
- Github Pages 博客网站访问速度优化