让前端飞

0322 - 响应 GitHub Webhooks 实现自动部署

2019-03-22  本文已影响9人  ITJason

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

前提条件

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

主要功能

主要配置

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

config.json

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

{
  "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 配置信息,用于发告知邮件:

{
  "mailConfig": {
    "host": "email-smtp.us-west-2.amazonaws.com",
    "port": "465",
    "user": "user123",
    "password": "password123",
    "from": "from@gmail.com",
    "to": "to@gmail.com"
  }  
}

琐碎的

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

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

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

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

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


博客原文:0322 - 响应 GitHub Webhooks 实现自动部署的 Web 服务

上一篇下一篇

猜你喜欢

热点阅读