跳到主要内容

利用 Github 的 Webhook 完成博客的自动部署

· 阅读需 2 分钟
Muel - Nova
Anime Would PWN This WORLD into 2D
🤖AI Summary

博主 nova 厌倦了每次通过 SSH 手动执行 git pull && npm run build 来部署博客,因此决定利用 GitHub 的 Webhook 实现自动部署。文章详细介绍了如何配置 GitHub 的 Webhook,并且提供了链接供读者参考。Webhook 的 URL 配置为公用 IP,content type 选择 json,并设置一个随机的 Secret 生成 HMAC 密钥。

后端使用 Go 的 gin 框架进行开发,主要任务是监听指定 URL,接收到 POST 请求后进行验证,再执行相应的命令。代码可在 nova 的 GitHub 仓库 MuelNova/go-github-build-hook 找到。由于构建时间较长,nova 将其放入一个协程中执行,后端快速返回状态码 200。

未来可能会在此基础上进行更多的自定义,甚至添加编译完成后的通知功能,例如通过 QQ 机器人通知编译状态。虽然这篇文章写得很轻松,但却是为了测试其效果而写的。

突然厌烦了每次要登 ssh,然后 git pull && npm run build 来部署 blog,于是就想到了 webhook

不过 package-lock.json 的 conflict 还是要自己修,后面想想有没有什么办法(直接把这玩意 ignore 啦!)

Webhook 配置

关于 web 挂钩 - GitHub 文档

直接看这个就完事了,在 REPO->Settings->Webhooks->Add webhook 处添加一个新的 Webhook

image-20230511190219973

image-20230511190315524

URL 就直接填公网 IP 就行,content type 我选了 json。

注意 Secret,这个就是用来生成 HMAC 的密钥,尽量填个随机一点的,后端倒时候也要用。

成功之后它会发送一个 ping,所以可以先不完成添加。

后端

后端的思路很简单,监听上面的 URL,等接到 POST 包验证,然后跑命令就行。

用的是 go 的 gin,直接添加就完事了。

代码可以在 MuelNova/go-github-build-hook 这里看。

唯一值得注意的大概就是因为 build 时间太长了,所以丢给一个协程自己跑就行,后端直接返回 200。

一开始写完测试的时候一直 timed out,还以为是什么问题。

没错这篇纯水,只是因为我想测试一下它的效果(笑

构思

因为 github 提供的消息挺全面的,所以后面估计会稍微的让他更自定义一点?或者添加一个推送啥的给 QQ 机器人,让我知道是什么时候编译完成了

Loading Comments...