在centos上搭建git服务器并自动同步代码

0

参考文章

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 git

2、创建”用户组“和”用户“,用来运行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 gitroot

4、安装Git客户端并生成公钥

4.1下载git客户端安装好后右键选择Git GUI Here->Help->Show SSH Key

image.png

image.png

就能得到私钥和公钥

image.png
打开Puttygenimage.png

image.png

load之前生成好的私钥image.png
得到格式化后的私钥,点击保存私钥image.png

配置小乌龟image.png
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克隆image.png
这样就把服务器的空仓库拉取下来了。
image.png

现在我们能够正常的提交代码到服务器的git,但是还不能自动同步,我们还需要修改服务器的hooks/post-receive文件。具体post-receive内容

#!/bin/sh
unset GIT_DIR  
DeployPath="/alidata/www/project"
LogPath="/alidata/gitroot/project.git/hooks"  
   
echo -e "\n=================  `date +"%Y-%m-%d %H:%M:%S"`  ===============\n" >> $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的时候还是要输入密码image.png

秘钥没有起作用-----------------------------解决办法:/var/log/secure查看一下日志,是否是.ssh的权限问题
chmod 700 .ssh
chmod 600 .ssh/authorized_keys

你可能感兴趣的

BoringTu · 2017年09月20日

自动同步?疯了啊?还是svn用习惯了?
git之所以比svn成熟,其中有一点就是可以本地commit,可以攒多个commit之后一并push到remote端,也可以在push之前反悔其中一个commit的改动而撤销掉。
其实最常用的,你在开发一个较大的功能模块,必然会有数个commit,但你不想在完成之前push上去。一个再正常不过的需求。那么你设置了自动同步还怎么玩儿?
如果还是停留在svn的思维模式上,真的没有必要用git的,好好的用svn就挺好的。

回复

BoringTu · 2017年09月20日

好吧,刚才先入为主了,仔细看了下你设置所谓“自动同步”的代码,那么问题又来了:

  1. 你这只是pull了master分支啊,没有push啊,那怎么能叫做“同步”呢?标题很有误导性
  2. 为什么要用pull,如果冲突了呢?除非你本人是没有修改只有读取master分支的权限的普通开发人员,那就当我没说
  3. 这种隐式的获取最新主分支代码的方式,很容易造成各种问题,比如你不会知道你本地的master当前是不是最新的(难道还要特意去看一下日志文件最后更新时间么?
    我尝试着各种角度去理解你的做法,都觉得很鸡肋,不会对开发效率有什么帮助,只会让开发流程变得更复杂和更加不确定性。

以上仅本人一点拙见

回复

0

感谢分享你的观点,本人刚解除git不久,如有不妥之处还望指正。首先这里的同步用到钩子,当本地提交代码后,post-receive会自动同步代码到站点下。二,git权限分发给的是用户组,就是说属于git用户组的都是能够提交并修改的,如果发生冲突diff,merge还是能够解决的。多用户开发时每次提交肯定要先拉取代码再提交的。

回眸淡然笑 作者 · 2017年09月21日
Hhao · 2018年09月10日

Host key verification failed.^M
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
这是什么原因啊?

回复

0

打开hooks/gitsync.log查看的错误日志

Hhao · 2018年09月10日
载入中...