部署Twikoo评论系统及其邮件推送(Vercel)
/封面.png)
部署Twikoo评论系统及其邮件推送(Vercel)
Aciano详细介绍了使用Vercel+MongoDB方案搭建Twikoo评论系统的过程,并实现邮件自动通知回复信息。
配置数据库
申请MongoDB账号
进入MongoDB注册一个账号。
创建MongoDB数据库
申请完毕后进入以下界面,选择最右边的免费共享数据库。
进入创建页面后,其他选项及配置保持默认,区域选择推荐AWS / N. Virginia (us-east-1)
区域选择完毕后,拉到页面底部点击Create进入下一步。
配置MongoDB数据库
ip设置为0.0.0.0/0即可:
创建数据库用户,请记住这里的password,后面步骤需要使用到。
回到Clusters页面,点击CONNECT
选择第二项:Connect your applicalion进入
进入以下页面,请记录你的数据库连接字符串,并将其中的<password>替换为你创建的数据库用户的密码。
这项数据库连接字符串将会在部署twikoo时使用到,请保存备用。
部署到Vercel
申请账号
申请一个Vercel账号,如已有Vercel账号可跳过这步。
部署仓库
点击以下链接将Twikoo一键部署到Vercel:
https://vercel.com/import/project?template=https://github.com/imaegoo/twikoo/tree/main/src/server/vercel-min
注:如果导入后出现空白界面或部署失败等现象,极大可能是Twikoo的仓库地址更换了,本文未能及时更新,可以自行前往Twikoo文档中获取部署链接:
https://twikoo.js.org/quick-start.html#vercel-%E9%83%A8%E7%BD%B2
在REPOSITORY NAME处随意输入一个仓库名字即可。
点击Create进入下一步。
等待Import进度跑完后,点击Visit进入仓库。
新建环境变量
进入Settings - Environment Variables页面。
新建一个NAME为MONGODB_URI;VALUE为你在前面记录到的数据库连接字符串的环境变量。
再次部署
进入Deployments界面,点击右边的竖三点,点击Redeploy
检验部署结果
回到Overview,点击Domains下方的链接,如果环境配置正确,可以看到 “Twikoo 云函数运行正常” 等字样。
Domains下方的链接即为后面需要使用到的环境id。
至此,Twikoo评论系统部署完成。
实现邮件通知
开通POP3/SMTP服务
以下教程以QQ邮箱为例,其他邮箱可自行摸索,原理大同小异。
前往你的邮件服务提供商,开通POP3/SMTP服务服务。
这里的授权码后面会用到,记得留存。
配置Twikoo
启用Twikoo
此部分教程以Butterfly主题为例说明,其他主题可参阅对应的使用文档。
打开[Blogroot]\_config.butterfly.yml主题配置文件,
1 | twikoo: |
填写环境id,再在comments-use中填写Twikoo即可。
部署到GitHub上后,进入一个有评论区的页面,点击输入框下的齿轮状按钮,设置你的管理密码。
配置邮件通知服务
进入配置管理 - 邮件通知,按照下方提供的标准填写即可。
1 | SENDER_EMAIL: <你的QQ邮箱地址> |
可参考我的配置:
测试
拉到最下方点击保存后,打开邮件通知测试,输入你的邮箱,点击发送测试邮件,如果能成功收到邮件即说明邮件通知服务设置成功!
参考文章
- Twikoo中文文档:https://twikoo.js.org/
- Twikoo Vercel 部署教程:https://www.bilibili.com/video/BV1Fh411e7ZH
- bufferfly主题的应用和即时推送:https://www.keyiqingxin.cn/317ea436/
特别鸣谢
@小石潭烤鱼,排查两天发现本教程的错处:
原Vercel的导入链接已失效,本教程未及时更新。
现2022年6月5日已替换为新链接。
现2022年8月1日已替换为新链接。
/%E7%94%B3%E8%AF%B7%E8%B4%A6%E5%8F%B7.png)
/%E9%80%89%E6%8B%A9%E6%95%B0%E6%8D%AE%E5%BA%93.png)
/%E5%88%9B%E5%BB%BA%E9%A1%B5%E9%9D%A2.png)
/%E9%85%8D%E7%BD%AEip.png)
/%E9%85%8D%E7%BD%AE%E7%94%A8%E6%88%B7.png)
/CONNECT1.png)
/CONNECT2.png)
/CONNECT3.png)
/%E5%88%9B%E5%BB%BA%E4%BB%93%E5%BA%93.png)
/Setting.png)
/redeploy.png)
/overview.png)
/%E5%BC%80%E9%80%9A%E6%9C%8D%E5%8A%A1.png)
/%E9%AA%8C%E8%AF%81%E5%AF%86%E4%BF%9D.png)
/%E6%8E%88%E6%9D%83%E7%A0%81.png)
/%E9%85%8D%E7%BD%AE1.png)
/%E9%85%8D%E7%BD%AE2.png)
/%E6%B5%8B%E8%AF%95%E6%88%90%E5%8A%9F.png)









