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

使用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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,889评论 19 139
  • 1. 安装 Github 查看是否安装git: $ git config --global user.name "...
    Albert_Sun阅读 14,657评论 9 163
  • 本文为 Git教程的学习笔记,教程源自廖雪峰的博客。这是一个由浅入深,学完后能立刻上手的Git教程。另,附上另一本...
    七弦桐语阅读 11,406评论 5 47
  • 1、“枝枝,我们今天下班后去看电影吧!听说周星驰的《美人鱼》挺不错的”枝枝的男友大柱发来微信。 “好呀,那我订票了...
    我不是蜗牛阅读 5,412评论 0 0
  • 昨晚吭哧吭哧写完一篇文章,已是将近夜里十一点。最近中了写字的毒,想要写点东西表达下自己。 写完迅速给老弟发过去,让...
    许多多的后花园阅读 3,698评论 0 0

友情链接更多精彩内容