通常大家開(kāi)發(fā)大部分是本地git push 提交,服務(wù)器上git pull 手動(dòng)更新。git 可以使用webhook實(shí)現(xiàn)自動(dòng)部署。
webhook是倉(cāng)庫(kù)平臺(tái)的一個(gè)鉤子事件,通過(guò)hook 鉤子監(jiān)聽(tīng)代碼,回調(diào)通知(通知地址就是你在各個(gè)git倉(cāng)庫(kù)平臺(tái)中填寫(xiě)的webhook地址,一般在你的某個(gè)項(xiàng)目倉(cāng)庫(kù)如myproject.git里面的設(shè)置中)倉(cāng)庫(kù)平臺(tái)填寫(xiě)的地址。
其實(shí)原理流程就是:

所以自動(dòng)部署主要實(shí)現(xiàn)方式就是:
- 修改代碼 push
- github(其他倉(cāng)庫(kù)平臺(tái))發(fā)送請(qǐng)求給你的網(wǎng)站服務(wù)器
- 網(wǎng)站服務(wù)器收到更新請(qǐng)求,執(zhí)行自動(dòng)部署腳本
- 自動(dòng)部署腳本執(zhí)行代碼拉取,打包,修改文件等動(dòng)作完成網(wǎng)站的更新部署
1. 下載github-webhook工具:
wget http://img.sgfoot.com/github-webhook1.4.1.linux-amd64.tar.gz
2. 運(yùn)行g(shù)ithub-webhook 安裝
tar -zxvf github-webhook1.4.1.linux-amd64.tar.gz
cp github-webhook /usr/bin/
chmod u+x /usr/bin/github-webhook
3.運(yùn)行方式
默認(rèn)端口: 2020,可以更改, http的路由: /web-hook
有效訪問(wèn)地址: http://ip:2020/web-hook
-b 是shell腳本路徑參數(shù)
-s 是github webhook設(shè)置的密碼
參數(shù)說(shuō)明:
# 非后臺(tái)運(yùn)行
github-webhook -b [shell腳本路徑] -s [github webhook設(shè)置的密碼]
# 后臺(tái)運(yùn)行
nohup github-webhook -b [shell腳本路徑] -s [github webhook設(shè)置的密碼]
# 定向日志輸出
nohup github-webhook -b ~/sh/你的腳本.sh -s hook密碼 >> ~/logs/webhook.log 2>1
特性介紹
- 直接運(yùn)行二進(jìn)制文件
- 自定義腳本路徑
- 自定義密碼
- 自定義端口. 0 ~ 65535
- 安靜模式
GLOBAL OPTIONS:
--bash value, -b value Execute the script path. eg: /home/hook.sh
--port value, -p value http port (default: 2020)
--secret value, -s value github hook secret
--quiet, -q quiet operation (default: false)
--verbose, --vv print verbose (default: false)
--help, -h show help (default: false)
--version, -v print the version (default: false)
翻譯:
GLOBAL OPTIONS:
--bash value, -b value Execute the script path. eg: /home/hook.sh 自定義腳本
--port value, -p value http port (default: 2020) 自定義端口,默認(rèn)6666
--secret value, -s value github hook secret 自定義密碼, 不允許為空
--verbose, --vv print verbose (default: false) 打印更多詳細(xì)信息
--quiet, -q quiet operation (default: false) 安靜模式,默認(rèn)關(guān)閉. -q 開(kāi)啟,不輸出任何信息
--help, -h show help (default: false)
--version, -v print the version (default: false)
上面介紹幾本參數(shù)使用。好了,言歸正傳:
部署腳本編寫(xiě),該 shell 腳本的主要目的是從 github 拉取代碼,腳本內(nèi)容很簡(jiǎn)單,只做了目錄的簡(jiǎn)要判斷,
代碼目錄存在則更新,不存在則克隆倉(cāng)庫(kù),工作目錄和倉(cāng)庫(kù)名稱、地址請(qǐng)換成大家自己的。
cd ~/
mkdir sh
vim webhook.sh
webhook.sh:
#!/bin/bash
cd /www/wwwroot/Golang/src
if [ ! -d "easy-gin" ]; then
git clone https://github.com/fantasylxh/easy-gin
fi
cd easy-gin
git pull
配置github webhook
- 填寫(xiě)你服務(wù)器的地址,http://ip:2020/web-hook
- 設(shè)置的密碼必須與服務(wù)器運(yùn)行
github-webhook -s設(shè)置的密碼一致.



啟動(dòng)本地的sh腳本:
github-webhook -b ~/sh/webhook.sh -s webhook123 >> ~/logs/webhook.log 2>1

確認(rèn)githup webhook連接是否正常:

測(cè)試webhook是否生效
git push后, 就可以看到github推送的信息,比如本地我新增push一個(gè)文件:

執(zhí)行Commit->push 之后,我們?cè)倏捶?wù)器代碼是否自動(dòng)更新:

到此:webhook 通訊正常。 sh腳本沒(méi)有驗(yàn)證當(dāng)前分支,只做了簡(jiǎn)單的pull,可以帶上-f 強(qiáng)制更新,有興趣的博友可以完善下sh。
總結(jié)
到此這篇關(guān)于GO 使用Webhook 實(shí)現(xiàn)github 自動(dòng)化部署的方法的文章就介紹到這了,更多相關(guān)GO 實(shí)現(xiàn)github 自動(dòng)化部署內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- docker利用WebHook實(shí)現(xiàn)持續(xù)集成
- Docker容器化部署Python應(yīng)用過(guò)程解析
- Docker如何部署Python項(xiàng)目的實(shí)現(xiàn)詳解
- 如何把python項(xiàng)目部署到linux服務(wù)器
- ansible-playbook實(shí)現(xiàn)自動(dòng)部署KVM及安裝python3的詳細(xì)教程
- Django+python服務(wù)器部署與環(huán)境部署教程詳解
- python+selenium定時(shí)爬取丁香園的新型冠狀病毒數(shù)據(jù)并制作出類似的地圖(部署到云服務(wù)器)
- Docker部署Python爬蟲(chóng)項(xiàng)目的方法步驟
- Linux部署python爬蟲(chóng)腳本,并設(shè)置定時(shí)任務(wù)的方法
- Python基于Webhook實(shí)現(xiàn)github自動(dòng)化部署