上次简单说了搭建Git服务器,这次来聊聊自动同步部署到项目。这种方式会很方便,比如用在网站上,只需要点一下push,线上的网站就会同步。这个教程的前提是网站放在Git服务器上。

前言

发现之前的文章有几处错误,又经过一大堆测试,直接登录git用户模拟了一遍操作等,终于找到比较完善的方法了。

解决疑难杂症

  1. 查看项目目录下的.git,所属是否是git用户的,如果不是需要修改
1
chown -R git:git .git
  1. git报错
1
2
3
4
5
6
7
8
9
[git用户 g]$ git pull
remote: Counting objects: 5, done.
remote: Compressing objects: 100% (3/3), done.
remote: Total 3 (delta 2), reused 0 (delta 0)
Unpacking objects: 100% (3/3), done.
From /git/g
528b0d2..9b2e4c3 master -> origin/master
Updating 528b0d2..9b2e4c3
error: unable to unlink old 'index.php' (Permission denied)

没有权限更新,解决这个问题可以使用sudo命令,但这样又会引出一个新问题。

  1. sudo问题

你需要先在/etc/sudoers文件中把执行sudo命令的用户加上,否则会报错

1
vim /etc/sudoers

把git用户加上,并且不需要密码

1
git ALL=(ALL)NOPASSWD:ALL

但sudo还有一个问题

1
2
3
4
5
6
7
8
[git@用户 g]$ sudo git pull
Updating 528b0d2..9b2e4c3
Fast-forward
index.php | 1 +
1 file changed, 1 insertion(+)

[git@用户 g]$ ll
-rw-r--r-- 1 root root 5105 Aug 14 19:03 index.php

就是用户和用户组变成了root,这样网页会打不开显示拒绝访问,就不得不使用chown来更换,所以Git钩子文件就得这样写。

Git钩子

在相应的Git项目目录中,进入hooks目录,新建或更改post-receive文件,用自己装的编辑器打开,使用命令。

1
vim post-receive

输入以下信息

1
2
3
4
5
6
#!/bin/sh
cd /www/wwwroot/myWebSite || exit
unset GIT_DIR
sudo git reset --hard
sudo git pull origin master
sudo chown -R www:www *

sudo git reset --hard是解决报错Your local changes would be overwritten by merge. Commit, stash or revert them to proceed,这是因为拉取代码时发现本地代码有过修改,所以提示你提交一下项目目录代码,但我们并不要提交,于是使用sudo git reset --hard可以放弃项目目录修改(其实不是修改,只是跟git上的不同),让拉取的代码覆盖项目目录的代码,实现硬更新。

sudo chown -R www:www *是把当前目录所有文件的所有者改为www用户和www用户组,这个用户是文件原本的用户,如果你的是其他的请自行更改,.git是隐藏目录所以不会被修改,但如果被修改需要你再改回来,在下面添加命令sudo chown -R git:git .git就可以。

这样就完成了,下次push项目后就会被触发,自动在myWebSite目录下拉取相应分支的更新、更改用户和用户组。

后言

像这种更改git用户获取权限不用密码的方式,我不确定安全性怎么样,还请大佬指教。