摘要:现在我们能够正常的提交代码到服务器的,但是还不能自动同步,我们还需要修改服务器的文件。具体内容先拉取再合并强制与远程服务器同步,不与本地合并,只能通过提交的客户端提交的方式修改代码。
参考文章
CentOS安装Git实现多人同步开发
centos中GIT服务器搭建及使用密钥连接
1、服务器上安装Git依赖及Git 2、创建Git用户及所属组 3、服务器上初始化Git仓库 4、安装Git客户端并生成公钥 5、创建证书登录 6、使用Git Bash克隆服务器上的空仓库 7、将本地库项目推送到服务器1、服务器上安装Git以及依赖
1.1安装Git依赖
yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel perl-devel
1.2.安装Git
yum install -y git2、创建”用户组“和”用户“,用来运行git服务
2.1创建用户组
groupadd git
2.2添加git用户组下的用户
adduser phper -g git
2.3为用户名为phper 的用户设置密码
passwd phper Changing password for user git. New password: Retype new password: passwd: all authentication tokens updated successfully.3、建立git仓库
mkdir gitroot chmown phper:git gitroot cd /gitroot git init --bare project.git chmown -R phper:git project.git chmod 774 -R project.git cd ../ chmod 750 gitroot4、安装Git客户端并生成公钥
4.1下载git客户端安装好后右键选择Git GUI Here->Help->Show SSH Key
就能得到私钥和公钥
打开Puttygen
load之前生成好的私钥
得到格式化后的私钥,点击保存私钥
配置小乌龟
4.2创建证书登录
切换到phper目录
cd /home/phper mkdir .ssh chmod 700 .ssh touch .ssh/authorized_keys chmod 600 .ssh/authorized_keys
然后将客户端的公钥上传到.ssh目录
cd .ssh rz
将公钥添加进authorized_keys中
cat id_rsa.pub >> authorized_keys
5、克隆到本地
右键选择git克隆
这样就把服务器的空仓库拉取下来了。
现在我们能够正常的提交代码到服务器的git,但是还不能自动同步,我们还需要修改服务器的hooks/post-receive文件。具体post-receive内容
#!/bin/sh unset GIT_DIR DeployPath="/alidata/www/project" LogPath="/alidata/gitroot/project.git/hooks" echo -e " ================= `date +"%Y-%m-%d %H:%M:%S"` =============== " >> $LogPath/gitsync.log 2>&1 cd $DeployPath #git stash #先拉取再合并 git pull origin master >> $LogPath/gitsync.log 2>&1 #强制与远程服务器同步,不与本地合并,只能通过提交的客户端提交的方式修改代码。 #git fetch --all #git reset --hard origin/master #time=`date` #echo "web server pull at webserver at time: $time." echo "================================================" >> $LogPath/gitsync.log 2>&1
更改post-receive的所有者和权限
chmod -R 774 post-receive chown phper:git post-receive
最后在www下
mkdir project chown -R phper:git project chmod -R 774 project cd /alidata/www git clone /gitroot/project.git
好了git的同步就弄好了
如果同步用不了,打开hooks/gitsync.log查看错误日志
可能预见的错误
1、fatal: /usr/libexec/git-core/git-pull cannot be used without a working tree.
同步的项目文件夹没有建立---------------解决办法:在www下建立project项目文件夹
2、fatal: Not a git repository (or any of the parent directories): .git
项目文件里没有git初始化------------------解决办法:在www路径下执行git clone /alidata/gitroot/project.git
3、error: cannot open .git/FETCH_HEAD: Permission denied
git在项目目录没有写入权限---------------解决办法:修改所有者以及权限 chown -R phper:git project / chmod -R 774 project
4、每次pull push的时候还是要输入密码
秘钥没有起作用-----------------------------解决办法:/var/log/secure查看一下日志,是否是.ssh的权限问题
chmod 700 .ssh
chmod 600 .ssh/authorized_keys
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/10374.html
摘要:现在我们能够正常的提交代码到服务器的,但是还不能自动同步,我们还需要修改服务器的文件。具体内容先拉取再合并强制与远程服务器同步,不与本地合并,只能通过提交的客户端提交的方式修改代码。 参考文章 CentOS安装Git实现多人同步开发centos中GIT服务器搭建及使用密钥连接 简述 1、服务器上安装Git依赖及Git 2、创建Git用户及所属组 3、服务器上初始化Git仓库 4、...
摘要:原文地址作为一个天天造的人,必然要经常访问谷歌等网站,所以前些日子买了自己搭了梯子。今天就跟大家分享一下,如何使用搭建个人博客。创建用户,建立裸库,配置。 原文地址:https://www.xksblog.top/use-V... 作为一个天天造BUG的人,必然要经常访问谷歌等网站,所以前些日子买了VPS自己搭了梯子。但如果只是用VPS来搭梯子那就太浪费了,所以又折腾了一天,把自己之...
摘要:导语上文介绍了怎么通过使用同步代码文件,到目前为止使用了近四个月。这种方式和互有利弊,总体来说还是更方便一些,下面记录下使用同步以及部署的过程。实际在最后一步的时候,也可以使用自动上传代码到,也就是整个流程只需要一次即可。 导语 上文介绍了怎么通过 PhpStorm 使用 FTP 同步代码文件,到目前为止使用了近四个月。这种方式和 Git 互有利弊,总体来说还是 Git 更方便一些,下...
摘要:在装有客户端的电脑使用执行得到如下界面输入回车,提示输入密码,无视继续回车走起结束后会在电脑用户名中生成一个文件这个文件会保存所有连接过的信息,下一次连接这个就不会有上面的提示了。六常识及注意事项提交时会自动忽略空文件夹 GIt安装和使用经验总结 此文是本菜鸡在实践多次git搭建内网服务版本库和GitHub上的使用总结部分参考了这位大佬的博客https://www.cnblogs.co...
摘要:本文从定义,作用,技术架构,安装和使用等全方位带你看懂。如图中左边红框中和右边的红框中都唯一表示为同一个镜像。最后,于开发者而言提供了一种开发环境的管理办法,与测试人员而言保证了环境的同步,于运维人员提供了可移植的标准化部署流程。 作者丨唐文广:腾讯工程师,负责无线研发部地图测试。 导语:Docker,近两年才流行起来的超轻量级虚拟机,它可以让你轻松完成持续集成、自动交付、自动部署...
阅读 3048·2021-11-24 09:38
阅读 1988·2021-11-23 09:51
阅读 1553·2021-10-13 09:39
阅读 2331·2021-09-23 11:53
阅读 1206·2021-09-02 15:40
阅读 3466·2019-08-30 15:54
阅读 996·2019-08-30 13:04
阅读 2401·2019-08-30 11:01