版本控制系统(git+gitolite)

前言:

成都创新互联公司是一家专注于成都网站设计、成都网站制作与策划设计,古塔网站建设哪家好?成都创新互联公司做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:古塔等地区。古塔做网站价格咨询:028-86922220

Git简介

Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码。2005年,为了解决Linux系统的源码开发管理这一问题,Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git,目前世界上最先进的分布式版本控制系统。2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等,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 clonehttps://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. 至此,成功clone下gitolite-admin目录即gitolite安装成功。

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

anaconda-ks.cfg  gitolite-admin

 

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

1. conf为配置文件目录

2. keydir为git客户端公钥目录

 

 

 

协作使用

开发人员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.pubroot@172.16.48.132:gitolite-admin/keydir

 

3. 访问仓库配置文件

版本控制系统(git + gitolite)

 

 

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密钥对应的仓库

版本控制系统(git + gitolite)

 

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的读写权限

版本控制系统(git + gitolite) 

 

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 -P22root@172.16.48.132:gitolite-admin/keydir

 

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

版本控制系统(git + gitolite) 

 

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

版本控制系统(git + gitolite)

[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


当前题目:版本控制系统(git+gitolite)
文章分享:http://scyanting.com/article/pecppg.html