如何使用Serverless Framework 部署个人博客到云平台

82次阅读
没有评论

共计 3129 个字符,预计需要花费 8 分钟才能阅读完成。

如何使用 Serverless Framework 部署个人博客到云平台,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面丸趣 TV 小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

本次实践涉及到的腾讯云云服务

Serverless Framework

COS(对象存储)

API 网关

DNSPod 域名注册、域名备案、域名解析

SSL 证书

CDN(内容分发网络)

域名购买与备案

2021/01/21 在  DNSPod(2011 年被腾讯收购)购买了域名  serverlesslife.cn 并进行了实名认证。

购买域名后,在中国大陆,要使用域名提供服务,还需要进行域名备案。

2021/1/31 在「腾讯云网站备案」小程序上提交了备案申请;

经过了两轮审核(腾讯云审核 + 管局审核)后,在 8 天后的 2021/02/07 审核通过。

Serverless Framework 简介

Serverless Framework 是
serverless.com  推出的一个流行的 Serverless 框架,它可以将 Serverless 函数 / 应用部署到不同的云厂商的 Serverless 平台。在国内腾讯云与  
serverless.com  达成战略合作,对它进行了很多定制,做了很多组件,使得很容易将 Serverless 函数 / 应用部署到腾讯云。

使用 Hugo 搭建个人博客

要搭建个人独立博客,有很多开源的建站工具可以用,比如:WordPress、Hexo、Jekyll、Hugo 等等,不胜枚举。

因为之前用过 Hugo,并且比较喜欢它,这里使用了 Hugo 来搭建个人博客。

Hugo 是由一个 Go 语言实现的静态网站生成器。简单、易用、高效、易扩展、快速部署。

Hugo 易扩展指的是它有丰富的主题可以选择,这是笔者喜欢它的原因之一,每个人都可以选择自己喜欢的主题。

在 Hugo 站点初始化后,在众多主题中选择了主题:LoveIt(多么好听的名字呀!)。

主题也有很多参数,可以根据自己的需求按需配置。

基本框架搭建完成后,如果要编写博文,只需要添加 Markdown 文件和相关静态资源文件。

Hugo 支持本地实时预览,可以一边写 markdown 文件,一边就能通过浏览器实时查看效果。

当然部署到生产服务器,需要进行编译,编译成站点的任务只要一条 hugo 命令就能完成。

站点源码托管在 GitHub 上:
https://github.com/serverlesslife-cn/serverlesslife

同时使用 GitHub Actions 将代码同步到了 Gitee:
https://gitee.com/serverlesslife/serverlesslife

部署站点

在站点编译后,使用 Serverless Framework CLI 便可将它部署到腾讯云。

Serverless Framework CLI 需要一个配置文件 serverless.yml,此时配置文件内容如下:

component: website # (必填)  引用  component  的名称,当前用到的是  tencent-website  组件
name: serverlesslife-2021 # (必填)  该  website  组件创建的实例名称
app: serverlesslife-2021 # (可选)  该  website  应用名称
stage: prod # (可选)  用于区分环境信息,默认值是  dev
inputs:
 src:
 src: ./public
 index: index.html
 region: ap-guangzhou
 bucketName: serverlesslife-2021
 protocol: https

其中 public 目录是 hugo 编译之后站点文件所在目录。

使用 serverless deploy 命令进行部署操作,如果没有在本地的 .env 配置 secretid 和 secretkey,需要使用微信进行扫描登录。

部署过程中,会在 COS 创建一个 bucket 并将 public 目录下的文件上传到这个 bucket 中,然后会生成一个腾讯云四级域名的访问地址。其中该 bucket 前缀是 serverlesslife-2021,工具会自动加上腾讯云账号的 APPID 作为后缀。

Serverless Framework 控制台下,会有一个应用名称为  serverlesslife-2021 的应用,这个应用会有一个腾讯云四级域名的访问地址,如下所示:

在 COS 对象存储的存储桶列表页,可以看到有一个名称为 serverlesslife-2021-1259061164  的 bucket,如下所示:

自定义域名 + SSL 证书 + 自动刷新 CDN

配置「自定义域名 + SSL 证书 + 自动刷新 CDN」还需要在 serverless.yml 中增加一些配置信息,整个 serverless.yml 文件如下:

component: website # (必填)  引用  component  的名称,当前用到的是  tencent-website  组件
name: serverlesslife-2021 # (必填)  该  website  组件创建的实例名称
app: serverlesslife-2021 # (可选)  该  website  应用名称
stage: prod # (可选)  用于区分环境信息,默认值是  dev

 - host: serverlesslife.cn  autoRefresh: true # 开启自动  CDN  刷新,用于快速更新和同步加速域名中展示的站点内容  onlyRefresh: false # 建议首次部署后,将此参数配置为  true,即忽略其他  CDN  配置,只进行刷新操作  https:  switch: on  http2: on  certInfo:  certId:  kBM9GLPt

上面的配置文件支持配置多个域名,每个域名下面还可以配置其他信息,如 SSL 证书 ID、自动刷新 CDN 等。

使用自定义域名时,如果需要配置 SSL 证书,那么就必须使用 CDN,因为在 CDN 下可以配置证书。

SSL 证书需要事先在 SSL 证书控制台申请,这里申请了一个免费证书,证书有效期一年,申请成功后会有一个 ID:kBM9GLPt,如下所示:

在配置好域名相关信息后,Serverless Framework 在部署后做了大量的事情,大大简化了配置成本。

如果不用 Serverless Framework 的话,那么就需要在不用云服务的控制台多个地方来回进行配置。

下面看下在配置「自定义域名 + SSL 证书」背后,Serverless Framework 都做了哪些事情:

1、CDN 控制台下,证书管理— 配置证书,将域名和证书关联到了一起,如下所示:

2、CDN 控制台下,域名管理— 添加域名,新增了一条记录,为 serverlesslife.cn 开启了静态加速,将 COS 静态网站作为源站点,并会生成 CNAME:

3、COS 控制台下,点进  serverlesslife-2021-1259061164 存储桶,在域名传输与管理— 自定义 CDN 加速域名处,也会看到有一条记录:

此时,要正常访问域名,还需要手动配置下域名解析:打开 DNSPod 控制台,为 serverlesslife.cn 添加一条 CNAME 记录,记录值为 CDN 生成的 CNAME:serverlesslife.cn.cdn.dnsv1.com。

注意:在首次部署后,将 onlyRefresh   参数配置为 true,即忽略其他 CDN 配置,只进行刷新操作,否则部署时间会相对比较长。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注丸趣 TV 行业资讯频道,感谢您对丸趣 TV 的支持。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-16发表,共计3129字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)