在Git版本控制中,本地push代码至git服务端后,线上web站点自动的pull拉取代码,实现代码同步。于是git的hooks钩子就是实现自动化更新的核心技术。
准备工作:(Gogs 和 Web服务都安装好)
1、 保证Gogs和web站点在同一台服务上。(如果不在同一服务器,只能考虑用web钩子了)
2、 Gogs创建远程仓库
3、 Web站点根目录,克隆一个仓库。(git克隆命令行你懂的)
Hooks配置
第一步:添加sh脚本
扫描二维码关注公众号,回复:
10275918 查看本文章
#!/bin/sh
export GIT_WORK_TREE=/www/wwwroot/patent.yunyii.cn
export GIT_DIR=${GIT_WORK_TREE}/.git
cd ${GIT_WORK_TREE}
git pull
第二步:设置web站点文件的权限
chown –R git:git /www/wwwroot/patent.yunyii.cn
因为git钩子是用的git用户权限,还有种可以全部给777 权限,推荐
第三步:设置用户名和密码
给web站点下的.git配置文件,修改带用户名密码的仓库地址。
vi /www/wwwroot/patent.yunyii.cn/.git/config
// 修改前
url = http://git.yunyii.cn/patent-sell.git
// 修改后
url = http://{登录用户名}:{登录密码}@git.yunyii.cn/patent-sell.git // 只修改这个地方就好
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
[remote "origin"]
url = http://root:[email protected]/patent-sell.git
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
综上:如果你用的是ssh秘钥来push代码,那就更好,第三步就可以省略了。