版本控制系统(git + gitolite)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了版本控制系统(git + gitolite)相关的知识,希望对你有一定的参考价值。

前言:

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服务器:

[[email protected] ~]# cat /etc/redhat-release

CentOS Linux release 7.4.1708 (Core)

[[email protected] ~]# ifconfig |awk 'NR==2 {print $2}'

172.16.48.132

 

1. 安装相应的依赖环境

[[email protected] ~]# yum install perl openssh git -y

 

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

[[email protected] ~]# useradd git

[[email protected] ~]# echo git|passwd --stdin git

[[email protected] ~]# ssh-keygen

[[email protected] ~]# cp /root/.ssh/id_rsa.pub /tmp/admin.pub

 

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

[[email protected] ~]# su - git

[[email protected] ~]$ mkdir bin

 

4. 下载gitolite源码

[[email protected] ~]$ git clone https://github.com/sitaramc/gitolite.git

 

5. 安装gitolite

[[email protected] ~]$ ./gitolite/install -to /home/git/bin/

[[email protected] ~]$ /home/git/bin/gitolite setup -pk /tmp/admin.pub

 

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

[[email protected] ~]$ su - root

[[email protected] ~]# git clone [email protected]:gitolite-admin.git

 

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

[[email protected] ~]# ls

anaconda-ks.cfg  gitolite-admin

 

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

1. conf为配置文件目录

2. keydirgit客户端公钥目录

 

 

 

协作使用

开发人员1服务器配置:

[[email protected] ~]# cat /etc/redhat-release

CentOS Linux release 7.4.1708 (Core)

[[email protected] ~]# ifconfig|awk 'NR==2 {print $2}'

172.16.48.129

 

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

[[email protected] ~]# ssh-keygen -f ~/.ssh/chentaicheng

[[email protected] ~]# ls ~/.ssh/

chentaicheng  chentaicheng.pub

 

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

[[email protected] ~]# scp -P22 -r -p ~/.ssh/chentaicheng.pub [email protected]:gitolite-admin/keydir

 

3. 访问仓库配置文件

技术分享图片

 

 

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

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

[[email protected] keydir]# pwd

/root/gitolite-admin/keydir

[[email protected] keydir]# ls

admin.pub  chentaicheng.pub

[[email protected] keydir]#

 

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

技术分享图片

 

3. 配置git

[[email protected] gitolite-admin]# pwd

/root/gitolite-admin

[[email protected] gitolite-admin]# git config --global user.email "[email protected]"

[[email protected] gitolite-admin]# git config --global user.name "chentaicheng"

 

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

[[email protected] gitolite-admin]# git add *

[[email protected] gitolite-admin]# git commit -m 'add new repo ctc by chentaicheng'

[[email protected] gitolite-admin]# git push

 

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

技术分享图片 

 

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

[[email protected] ~]# git clone gitolite:ctc         

Cloning into 'ctc'...

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

warning: You appear to have cloned an empty repository.

[[email protected] ~]# ls

anaconda-ks.cfg  ctc

[[email protected] ~]# cd ctc/

[[email protected] ctc]# git config --global user.email "[email protected]"

[[email protected] ctc]# git config --global user.name "CTC"

[[email protected] ctc]# git add readme.txt

[[email protected] ctc]# git commit -m 'add readme.txt'                   

[[email protected] ctc]# git push origin master

至此,git+gitolite部署完毕。

 

 

 

 

 

 

 

 

 

 

 

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

开发人员2环境:

[[email protected] ~]# cat /etc/redhat-release

CentOS Linux release 7.4.1708 (Core)

[[email protected] ~]# ifconfig|awk 'NR==2 {print $2}'

172.16.48.133

 

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

[[email protected] ~]# mkdir .ssh

[[email protected] ~]# ssh-keygen -f .ssh/develop

[[email protected] ~]# scp -P22 [email protected]:gitolite-admin/keydir

 

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

技术分享图片 

 

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

技术分享图片

[[email protected] gitolite-admin]# pwd

/root/gitolite-admin

[[email protected] gitolite-admin]# git add *

[[email protected] gitolite-admin]# git commit -m 'add develop'

[[email protected] gitolite-admin]# git push

 

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

[[email protected] ~]# git clone gitolite:ctc

[[email protected] ~]# ls

anaconda-ks.cfg  ctc

[[email protected] ~]# cd ctc/

[[email protected] ctc]# ls

readme.txt


以上是关于版本控制系统(git + gitolite)的主要内容,如果未能解决你的问题,请参考以下文章

Git配置使用gitolite控制权限

linux服务器上搭建gitolite实现对git server的版本库的权限控制

使用Gitolite搭建Git服务器

centos7 安装 gitolite (git服务器)

使用Gitolite来对Git的repository实现权限控制

[转载] 使用Gitolite来对Git的repository实现权限控制