美文网首页
一键同步部署本地代码到服务器

一键同步部署本地代码到服务器

作者: 一只长毛猫 | 来源:发表于2016-12-24 10:52 被阅读4748次

使用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

相关文章

网友评论

      本文标题:一键同步部署本地代码到服务器

      本文链接:https://www.haomeiwen.com/subject/hqpkvttx.html