优雅使用Jsdelivr/CDN加速博客访问速度

前言

CDN的全称是Content Delivery Network,即内容分发网络。CDN是构建在网络之上的内容分发网络,依靠部署在各地的边缘服务器,通过中心平台的负载均衡、内容分发、调度等功能模块,使用户就近获取所需内容,降低网络拥塞,提高用户访问响应速度和命中率。CDN的关键技术主要有内容存储和分发技术。——百度百科

说明:我们把博客文件部署到github上难免会加载起来很慢,但是并不是没有办法滴。优雅使用CDN加速来优化网站打开速度,jsDelivr /cdn + Github。

开始操作

前期准备

  1. 一个 Github 账号
  2. 可以登录 GitHub
  3. 懂得如何向 GitHub 仓库 push 文件

关于 Github 仓库可以新建,也可以使用 <用户名>.github.io 这个仓库。这里我就新建一个仓库为例。

正式开始

  1. 新建创库

    仓库名称与描述自定义,但仓库一定要公开,不能是私有哦!

创建完创库后我们可以用命令行初始化创库,具体操作创建完创库会给出提示怎么做的了,我这里教你本地上传文件,再次上传只需要拖到初始化的文件夹上传就OK了。

  1. 本地新建一个文件夹,文件夹名称自定义,然后进入文件夹,在文件夹内依次执行下面的命令

  2. 接着在本地新建的文件下,右击->git bash,请确认你已安装git分布系统了

git init
git remote add origin 你新建仓库的HTTP或者SSH地址链接
git pull origin master #将仓库拉取到本地文件夹

然后呢,把你要上传的文件放进这个文件夹内(可以多层目录滴)

在这里插入图片描述
4.上传文件,依次执行下面的命令

git add .    #(.表示所有的)
git commit -m '添加文件内容描述' 
git push origin master   #将本地仓库文件推送到GitHub新建的仓库
  1. 然后呢,到github仓库库预览效果,若能看到上传的文件则说明推送成功了,接下来发布仓库->点击release,进行版本的发布


6. 自定义发布版本号,添加标题和描述等即可

在这里插入图片描述7. 通过jsdelivr引用资源

  • 使用方法:https://cdn.jsdelivr.net/gh/你的用户名/你的仓库名@发布的版本号/文件及路径

  • 例如:https://cdn.jsdelivr.net/gh/chuchendjs/HexoStaticFlie@1.0/butterfly/css/friendlink.css

    注意:版本号不是必需的,是为了区分新旧资源,如果不使用版本号,将会直接引用最新资源

  1. 若再次仓库里添加或者修改文件,首先把文件添加到本地仓库,然后依次在本地仓库文件位置执行以下命令:
git pull origin master  #拉取远程仓库到本地
git add .
git commit -m '描述内容'
git push origin master  # 推送到GitHub仓库

常见问题

以上的方式简单粗暴,上传即可,但是这种方式存在几个问题。

JSD 的链接是什么

在我上图的链接为 https://cdn.jsdelivr.net/gh/chuchuendjs/HexoStaticFile/css/friendlink.css,但是并不意味着 JSD 只有这一种引用方式。

  1. 直接引用
    格式为:https://cdn.jsdelivr.net/gh/<用户名>/<仓库名>/<文件及路径>
    例如: https://cdn.jsdelivr.net/gh/chuchuendjs/HexoStaticFile/css/friendlink.css
  2. 分支及版本号
    分支与版本号加到仓库后,用 @符链接。
    格式为: https://cdn.jsdelivr.net/gh/<用户名>/<仓库名>@[分支/版本号]/<文件及路径>
分支名描述特点
普通分支即 GitHub 的分支,可以创建多个,默认为 master按分支引用
latest 最后一次提交每上传一个新文件,都可以用这个分支引用。即不加版本号的默认情况。
版本号指定版本的内容,需配合版本发布已发布的版本不会受到仓库内容变化的影响 ,上面已经展示了如何引用

关于缓存问题

据我所知,不仅与分支有关系且与文件名有关系。文件名为 * .min. * 或者是 * *,也就是带 min 的和不带 min 的。这里我以 index.min.css index.css 为例。

  1. index.css
分支首次上传能否及时更新缓存天数
master可以被引用第一次 push 和第一次修改可以更新可能 1 天
latest 可以被引用master 分支几乎一致可能 1 天
版本号发布版本后引用发布后及时更新每个版本独立
  1. index.min.css
分支第一次上传能否及时更新缓存天数
master可以被引用第一次 push 可以更新可能 1 天
latest可以被引用第一次 push 和第一次修改可以更新可能 1 天
版本号发布版本后引用发布后及时更新每个版本独立

文件是否有限制

  1. GitHub 公开仓库大小为 100GB,所以不用担心不够用的问题了。并且你可以创建无数个仓库哟!

    注意:100GB 我们并不能全用完滴,可能每个仓库不能超过 1G。超过 1G 后会有人工审核仓库内容,若发现用来做图床,轻则删库,重则封号

    建议在 1G 之前就应该换个仓库了!

  2. 文件大小

    Github 单文件上传为 100M,但是 JSD 加速的单文件大小为 50M。所以也就意味着单文件大小为50MB

  3. 文件类型

    图片视频静态文件基本都是可以滴。

总结

  • 图床(不需要修改文件)

    使用 latest 分支或者 master分支即可。

  • 静态文件仓库,即 css,js等文件(经常改动文件)

    建议使用版本号方式,因为发布后可以及时更新到

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值