使用git, 在服务器建立一个中心仓库,在本地clone一份,在服务器/www/test目录下clone一份。 本地代码提交到中心仓库时,触发中心仓库的钩子,使/www/test自动去中心仓库,拉去最新代码。下面以本地Mac+CenterOS服务器为例。
第一步:服务器端配置
在服务器端开启git服务器。如果没有git请先安装
adduser fwgit //fwgit是你自己随意命名的git用户名,执行完毕后,在/home目录下可以找到fwgit用户
然后打开rsa认证
vi /etc/ssh/sshd_config
RSAAuthentication yes
PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys //指定公钥存放位置,具体在哪儿,继续往下看
创建用户fwgit的ssh
cd /home/fwgit
mkdir .ssh
cd .ssh
vi authorized_keys //要把你本地的公钥拷贝到这个文件里
上面几个操作是在远程服务器上做的,接下来获取自己本地电脑的公钥,是你在本地提交到远程仓库的一个通行证
cd ~/.ssh //目录下查看, id_rsa 、id_rsa.pub,若没有,则用下面命令生成
ssh-keygen -t rsa -C "youremail@example.com" //一路回车
就可以生成文件 id_rsa 、id_rsa.pub
打开公钥id_ras.pub,拷贝下面一整行的内容:
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDSkyZC9Owshc8x1Mzk5LU+dpqpYc1X761IqZnw8gVfG+Fcfspxj5VYsCeC5Uxxx3fT5JV9LvwWt5k40WaDKaeGbwNv9gOKv06ti23iRVS+YA5ufzlfOQkrbcxfK0BqhHTPZCGsm+xtpk7YrUyygOIUT29Nk6GjRsFgVfgL6l2oJq2/z4owFYW9GLH1eFXiQYrRM/N2qO9ICyJLbBPYumV6Bbi+yVbtHmEOvMNx2XyU6hIMfA/CuUjD6HpOu6rpJaggEGrWo4LAwTlQ0y2oMr2b/VWyBXBfzavD3H6GY+FQmQrJqYRkIDKZVl1INOFnqD3LpLKS9IAf1d3
放入服务器文件 /home/fwgit/.ssh/authorized_keys中,即可。
为了防止,本地用fwgit ssh fwgit:@112.74.124.87登录,我们需要在服务器端禁用shell登录
vi /etc/passwd //找到类似下面一行
fwgit:x:1000:1000::/home/fwgit:/bin/bash //原来的
fwgit:x:1000:1000::/home/fwgit:/usr/bin/git-shell //改为现在的
这样,git用户可以正常通过ssh使用git,但无法登录shell,因为我们为git用户指定的git-shell每次一登录就自动退出。
最后:本地和服务器都需要设置邮箱和名字
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
第二步:创建仓库
服务器端裸仓库的创建
假设你的根目录下有个git文件夹 /git,我们在git文件夹下,创建一个叫test.git的文件夹
cd /git
mkdir test.git
git init --bare test.git //裸仓库没有工作区
钩子设置
当本地推送上来时候,触发钩子,将内容更新到/www/test目录下
cd /git/test.git/hooks
vi post-receive
//post-receive增加下面两行
cd /www/test
env -i git pull
最后改变权限和所属
chown fwgit:fwgit test.git //把test.git所属的用户和用户组改为fwgit
chmod -R 777 test.git //给予较高的权限
web仓库搭建
cd /www
mkdir test
git clone /git/test.git test //clone到test文件夹
chmod -R 777 test
chown -R fwgit:fwgit test //这个不加上,会导致钩子中的git pull 失败
本地仓库搭建
git clone fwgit@47.88.148.22:/git/test.git //默认在当前文件夹下生产一个test文件
cd test
vi index.php //随便写点内容
git add index.php
git commit -m "create new file"
git push 推送到服务器
这时,你就可以看到服务器端 /www/test目录下,多了一个index.php文件。
本地仓库,执行git push时,会把本地代码,推送到服务器端的裸仓库test.git中,test.git在收到推送后,会去触发post-receive中设定的方法,让web仓库来pull更新。
如果失败,基本都是权限问题和用户所属组问题。
chmod -R 777 xxx
chown -R fwgit:fwgit xxx
xxx 值中心仓库 test.git , 服务器上的clone文件 /www/test