搭建 Git 服务器、编写自动部署脚本
今天试了下在 linux 服务器上搭建 Git 服务器,并且编写一个简单的自动部署脚本。
主要参考 廖雪峰 -GIT 教程 - 搭建 Git 服务器
现在开始吧!
创建一个 git 用户,用来运行 git 服务
adduser git
创建证书登录
收集所有需要登录的用户的公钥,就是他们自己的 id_rsa.pub 文件,把所有公钥导入到 /home/git/.ssh/authorized_keys 文件里,一行一个。
初始化 Git 仓库
先选定一个目录作为 Git 仓库,假定是 /home/git/sample.git,在/home/git 目录下输入命令:
git init --bare sample.git
Git 就会创建一个裸仓库,裸仓库没有工作区,因为服务器上的 Git 仓库纯粹是为了共享,所以不让用户直接登录到服务器上去改工作区,并且服务器上的 Git 仓库通常都以.git 结尾。然后,把 owner 改为 git
chown -R git:git sample.git
禁用 git 用户 shell 登录
通过编辑 /etc/passwd 文件完成,找到你的 git 用户的一行, 例如:
git:x:1001:1001:,,,:/home/git:/bin/bash
把 /bin/bash 改为/usr/bin/git-shell, 例如:
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
这样,git 用户可以正常通过 ssh 使用 git,但无法登录 shell,因为我们为 git 用户指定的 git-shell 每次一登录就自动退出。
克隆远程仓库
git clone git@server:sample.git
server 是你的服务器域名或 ip 地址
如果 git 仓库和 web 目录在同一台服务器主机上:
git clone /home/git/sample.git
如果不是在 git 用户的家目录中创建的, 比如 /srv/gits/sample.git:
git clone git@server:/srv/gits/sample.git
如果 clone 成功,那么你的 git 服务器就搭建成功了。
接下来:
自动同步钩子脚本
因为我是 web 目录和 git 是同一台服务器
编辑 /home/git/sample.git/hooks/post-receive, post-receive就是在 git 服务器收到代码推送后 (push 完成之后) 执行的脚本。
#!/bin/sh
while read oldrev newrev refname
do
branch=$(git rev-parse --symbolic --abbrev-ref $refname)
if ["master" == "$branch"]; then
# Do something
echo "post-receive in branch master" >> /tmp/git-sample.log
unset GIT_DIR
wwwPath=/var/www/html/sample
cd $wwwPath && /usr/bin/git pull origin master
exit 0
fi
done
从脚本内容可以看出,我们在判断当前 push 的分支是 master 时执行 git pull origin master 操作。
给执行权限:
chown -R git:git /home/git/sample.git/hooks/post-receive
chmod +x /home/git/sample.git/hooks/post-receive
因为是 git 仓库和 web 目录在同一台服务器主机上, 这里 clone 使用的是:
git clone /home/git/sample.git
因为同步脚本的执行用户是 git,所以要保证项目目录要赋予 git 写权限。容易出问题的也是权限问题。
好了,试试吧~
原文连接:
搭建 Git 服务器 - 编写自动部署脚本
更多分享知识点, 请扫码关注: