C语言学习网

版本控制系统(git + gitolite)

发表于:2022-08-13 作者:安全数据网编辑
编辑最后更新 2022年08月13日,前言:Git简介Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与

前言:

Git简介

Linus1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码。2005年,为了解决Linux系统的源码开发管理这一问题,Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git,目前世界上最先进的分布式版本控制系统。2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQueryPHPRuby等等,Git迅速成为最流行的分布式版本控制系统。(目前,绝大多数Linux已自带git软件


Gitolite简介

如果不是要和他人协同开发,Git 根本就不需要架设服务器。Git 在本地可以直接使用本地版本库的路径完成 git 版本库间的操作。但是如果需要和他人分享版本库、协作开发,就需要能够通过特定的网络协议操作 Git 库。Git 支持的协议很丰富,架设服务器的选择也很多,不同的方案有着各自的优缺点。Gitolite 是一个轻量级开源项目,使用SSH公钥认证,能做到分支级的权限控制。对于个人,中小型企业及一些开源项目而言,如果没有特殊的要求Gitolite提供的服务已经足够用。

Gitolite安装

实验环境:

Gitolite服务器:

[root@linux-node1-gitolite-server ~]# cat /etc/redhat-release

CentOS Linux release 7.4.1708 (Core)

[root@linux-node1-gitolite-server ~]# ifconfig |awk 'NR==2 {print $2}'

172.16.48.132

1. 安装相应的依赖环境

[root@linux-node1-gitolite-server ~]# yum install perl openssh git -y

2. 创建git用户,生成用于管理gitolite的公钥和私钥

[root@linux-node1-gitolite-server ~]# useradd git

[root@linux-node1-gitolite-server ~]# echo git|passwd --stdin git

[root@linux-node1-gitolite-server ~]# ssh-keygen

[root@linux-node1-gitolite-server ~]# cp /root/.ssh/id_rsa.pub /tmp/admin.pub

3. 切换到git用户下创建安装目录

[root@linux-node1-gitolite-server ~]# su - git

[git@linux-node1-gitolite-server ~]$ mkdir bin

4. 下载gitolite源码

[git@linux-node1-gitolite-server ~]$ git clone https://github.com/sitaramc/gitolite.git

5. 安装gitolite

[git@linux-node1-gitolite-server ~]$ ./gitolite/install -to /home/git/bin/

[git@linux-node1-gitolite-server ~]$ /home/git/bin/gitolite setup -pk /tmp/admin.pub

6. 切换到root用户下,clone gitolite-admin.git

[git@linux-node1-gitolite-server ~]$ su - root

[root@linux-node1-gitolite-server ~]# git clone git@172.16.48.132:gitolite-admin.git

7. 至此,成功clonegitolite-admin目录即gitolite安装成功。

[root@linux-node1-gitolite-server ~]# ls

anaconda-ks.cfg gitolite-admin

注:gitolite是通过管理gitolite-admin来对仓库进行授权管理的。

1. conf为配置文件目录

2. keydirgit客户端公钥目录

协作使用

开发人员1服务器配置:

[root@linux-node0-manager ~]# cat /etc/redhat-release

CentOS Linux release 7.4.1708 (Core)

[root@linux-node0-manager ~]# ifconfig|awk 'NR==2 {print $2}'

172.16.48.129

1. 在开发人员1服务器上生成公钥私钥

[root@linux-node0-manager ~]# ssh-keygen -f ~/.ssh/chentaicheng

[root@linux-node0-manager ~]# ls ~/.ssh/

chentaicheng chentaicheng.pub

2. 将公钥chentaicheng.pub存放到gitolite服务器的gitolite-admin/keydir目录下

[root@linux-node0-manager ~]# scp -P22 -r -p ~/.ssh/chentaicheng.pub root@172.16.48.132:gitolite-admin/keydir

3. 访问仓库配置文件


gitolite服务器上配置chentaicheng密钥对应的仓库及权限:

1. 检查chentaicehng.pub是否存在gitolite-admin/keydir目录下

[root@linux-node1-gitolite-server keydir]# pwd

/root/gitolite-admin/keydir

[root@linux-node1-gitolite-server keydir]# ls

admin.pub chentaicheng.pub

[root@linux-node1-gitolite-server keydir]#

2. 配置chentaicheng密钥对应的仓库

3. 配置git

[root@linux-node1-gitolite-server gitolite-admin]# pwd

/root/gitolite-admin

[root@linux-node1-gitolite-server gitolite-admin]# git config --global user.email "chentaicheng@qq.com"

[root@linux-node1-gitolite-server gitolite-admin]# git config --global user.name "chentaicheng"

4. 将修改后的配置及公钥更新到gitolite服务器

[root@linux-node1-gitolite-server gitolite-admin]# git add *

[root@linux-node1-gitolite-server gitolite-admin]# git commit -m 'add new repo ctc by chentaicheng'

[root@linux-node1-gitolite-server gitolite-admin]# git push

检查开发人员1是否能获取仓库ctc的读写权限

Clone ctc仓库并增加内容然后提交到远程仓库上

[root@linux-node0-manager ~]# git clone gitolite:ctc

Cloning into 'ctc'...

Enter passphrase for key '/root/.ssh/chentaicheng':

warning: You appear to have cloned an empty repository.

[root@linux-node0-manager ~]# ls

anaconda-ks.cfg ctc

[root@linux-node0-manager ~]# cd ctc/

[root@linux-node0-manager ctc]# git config --global user.email "791582297@qq.com"

[root@linux-node0-manager ctc]# git config --global user.name "CTC"

[root@linux-node0-manager ctc]# git add readme.txt

[root@linux-node0-manager ctc]# git commit -m 'add readme.txt'

[root@linux-node0-manager ctc]# git push origin master

至此,git+gitolite部署完毕。

开发人员2获取开发人员1push的代码

开发人员2环境:

[root@linux-node2-develop ~]# cat /etc/redhat-release

CentOS Linux release 7.4.1708 (Core)

[root@linux-node2-develop ~]# ifconfig|awk 'NR==2 {print $2}'

172.16.48.133

1. 在开发人员2主机上生成密钥对,并将密钥传输到gitolite服务的gitolite-admin/keydir目录下

[root@linux-node2-develop ~]# mkdir .ssh

[root@linux-node2-develop ~]# ssh-keygen -f .ssh/develop

[root@linux-node2-develop ~]# scp -P22 root@172.16.48.132:gitolite-admin/keydir

2. 配置develop密钥对应的仓库

3. gitolite修改配置文件,并更新到gitolite服务器上,使开发人员2ctc仓库具有读写权限。

[root@linux-node1-gitolite-server gitolite-admin]# pwd

/root/gitolite-admin

[root@linux-node1-gitolite-server gitolite-admin]# git add *

[root@linux-node1-gitolite-server gitolite-admin]# git commit -m 'add develop'

[root@linux-node1-gitolite-server gitolite-admin]# git push

4. 开发人员2获取开发人员1push的代码

[root@linux-node2-develop ~]# git clone gitolite:ctc

[root@linux-node2-develop ~]# ls

anaconda-ks.cfg ctc

[root@linux-node2-develop ~]# cd ctc/

[root@linux-node2-develop ctc]# ls

readme.txt


0