0322 - 响应 GitHub Webhooks 实现自动部署的 Web 服务

今天研究并实现一个响应 GitHub Webhooks 实现自动部署的 Web 服务。简单收拾了下代码和文档,开源至此

前提条件

这并不是一个 Hello Word 教学示例,而是我自己在用的实际项目。假设你已经知道下列技术或满足其条件:

  • 有一台自己的服务器
  • 会配置域名
  • 会配置 nginx 或者其他 Web 服务器,实现 Web 服务至 node 服务的转发
  • 了解 node、koa
  • 了解 Webhooks
  • 了解 SMTP
  • 会编辑 shell 脚本

主要功能

  • node lib/index.js 运行后,在 3030 端口提供可响应 GitHub Webhook 的服务
  • 内部通过 exec 来调用实际工作的 shell 脚本(需要自己编写)
  • 发邮件告知运行结果

主要配置

均位于 config 目录,参照 *_demo.json,添加没有 _demo 的版本

config.json

可为每个仓库、分支创建对应的配置:

1
2
3
4
5
6
7
8
9
10
{
"webhook-test_master": { // RepositoryName_BranchName
"secret": "GitHub_Webhook_secret",
"cwd": "/home/jason/testapi/", // 脚本执行目录
"command": "/bin/bash ./deploy.sh", // 真正工作的 shell 脚本
"env": { // 一些环境变量
"DEBUG": "s:*"
}
}
}

security.json

目前主要存储了 SMTP 配置信息,用于发告知邮件:

1
2
3
4
5
6
7
8
9
10
{
"mailConfig": {
"host": "email-smtp.us-west-2.amazonaws.com",
"port": "465",
"user": "user123",
"password": "password123",
"from": "[email protected]",
}
}

琐碎的

关于 GitHub Webhook,记得生成密码、选择 json 格式。

关于 shell 脚本,可以通过 2>&1 将其中不重要的 warn/error,从 stderr 转到 stdout 中。

关于邮件服务,我开始时用的是阿里云,但出现了提示发送成功、但实际不破功的情况,垃圾箱也没有。后来试了 Amazon SES,目前一切顺利;每天 200 封免费邮件额度。

使用 VSCode 编写调试,.vscode 配置本身也包含在项目中了。

如果你遇到了问题,多问问 Google 和自己;我这边是顺畅运行的。