转载:配置Github Webhooks自动部署项目

转载自:利用Github的Webhook功能和Node.js完成项目的自动部署

首先完成Node.js服务器的代码构建,先上代码,再解释

var http = require('http')
var createHandler = require('github-webhook-handler')
var handler = createHandler({ path: '/', secret: 'root' })
// 上面的 secret 保持和 GitHub 后台设置的一致

function run_cmd(cmd, args, callback) {
  var spawn = require('child_process').spawn;
  var child = spawn(cmd, args);
  var resp = "";

  child.stdout.on('data', function(buffer) { resp += buffer.toString(); });
  child.stdout.on('end', function() { callback (resp) });
}

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);
    run_cmd('sh', ['./deploy.sh',event.payload.repository.name], function(text){ console.log(text) });
})

上面的代码中用到了一个github-webhook-handler的中间件,你可以用 npm install -g github-webhook-handler 来全局安装。

还有代码这行:

var handler = createHandler({ path: '/', secret: 'root' }) 

其中secret后的参数是你在github的项目中添加webhook时设置的secret值,替换成自己的就行了

完成deploy.sh脚本

deploy.sh脚本负责进入项目的目录,然后利用git命令拉取最新的代码,还是直接贴代码:

#!/bin/bash

WEB_PATH='/root/tools/'$1
WEB_USER='root'
WEB_USERGROUP='root'

echo "Start deployment"
cd $WEB_PATH
echo "pulling source code..."
git reset --hard origin/master
git clean -f
git pull
git checkout master
echo "changing permissions..."
chown -R $WEB_USER:$WEB_USERGROUP $WEB_PATH
echo "Finished."

deploy.sh 会接受第一个参数当做项目名字,然后进入这个项目的目录执行git操作,这个参数是在deploy.js中根据hook返回的项目名字来的,代码应该比较容易懂,都是些简单的git命令。

如果是全新的项目,需要在你的服务器上先clone要部署的项目
你需要根据自己的实际项目位置,修改WEB_PATH的值

后台运行deploy.js

利用Linux提供的nohup命令,让deploy.js运行在后台

nohup node deploy.js > deploy.log &

去Github后台添加webhook

进入你需要自动部署的项目的github地址,进入项目的设置页面,点击左侧的 Webhooks & services
!hithub-webhook