Git + Webhook + Node.js实现服务器自动化更新部署

扫描二维码

在我们做本地和服务器代码同步的过程中,实现本地push,服务器自动监听更新,并重启应用服务。这个过程需要git+webhook+Node.js来实现。本篇说明仅针对Node.js的监听实现。

1、配置Webhook

在Github、Gitlab、Gitee等线上仓库配置Webhook

2、服务器安装监听服务

服务器上需要安装NodeJS环境,安装方法请自己去官网查阅。

然后执行命令全局安装:

npm install http-server -g
npm install git-webhook-handler -g

3、增加webhook监听脚本

在项目目录下新建 webhook.js,这个js实现的是启动一个自进程服务,来监听端口,接收webhook发送过来的请求,并执行相应的.sh启动脚本来实现代码的自动更新。

var http = require('http')
var createHandler = require('git-webhook-handler')
var handler = createHandler({ path: '/webhook', secret: 'xxxxx' })

function RunCmd(cmd, args, cb) {
      var spawn = require('child_process').spawn;
      var child = spawn(cmd, args);
      var result = '';
      child.stdout.on('data', function(data) {
            result += data.toString();
      });
      child.stdout.on('end', function() {
            cb(result)
      });
}

http.createServer(function (req, res) {
      handler(req, res, function (err) {
        res.statusCode = 404;
        res.end('no such location');
      })
}).listen(7777)

handler.on('error', function (err) {
    console.error('Error:', err.message);
})

handler.on('push', function (event) {
    console.log('Received a push event for %s to %s',
    event.payload.repository.name,
    event.payload.ref);
      var shpath = './project-start.sh';
      RunCmd('sh', [shpath], function(result) {
          console.log(result);
      })
})
  • git-webhook-handler:是处理git的webhook的包
  • secret:是上面第1步操作创建webhook时的secret,
  • 7777:监听7777端口,这个端口可以根据个人情况自行调整。
  • project-start.sh: 代码的同步更新脚本
  • git-webhook-handler找不到的处理:执行脚本的过程中可能出现包不存在的情况,在项目下执行:npm link git-webhook-handler

如何启动这个脚本呢?

我这里用的是pm2,全局安装pm2

npm i pm2 -g

到项目根目录下,执行启动命令

pm2 start webhook.js

4、代码同步更新启动脚本

project-start.sh脚本,仅供参考,更加自己实际情况调整:

#!/bin/bash

## 进入项目目录
echo '进入项目根目录>>>>'
cd /root/app/my-project
## 拉取最新代码
echo '开始最新代码>>>>'
git pull
## 执行项目的build
echo 'build项目'
yarn build
## 重新启动项目
pm2 start
echo '项目重启完成!!'

5、配置nginx

需要把监听脚本的 7777 端口对外开放,让Git的Webhook请求到。

server {
        listen       80;
  ...
              location /webhook {
                proxy_pass http://localhost:7777/webhook;
        }
}

重启nginx是的配置生效

nginx -s reload

6、验证配置结果

以上设置完成后,就可以进行本地push的验证,代码仓库收到变动会调用webhook请求我们的服务器,服务器收到请求后,启动project-start.sh脚本,拉取代码,重启启动项目。

查看webhook调用结果:

Untitled

查看服务器监听脚本日志:

根据 pm2 list 来查看进程 id, 然后通过 pm2 log xx 来查看脚本生成日志。

Untitled