版本控制系统(git + gitolite)
前言:
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 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 [email protected]: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.pub [email protected]: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 "[email protected]"
[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 "[email protected]"
[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 [email protected]:gitolite-admin/keydir
2. 配置develop密钥对应的仓库
3. gitolite修改配置文件,并更新到gitolite服务器上,使开发人员2对ctc仓库具有读写权限。
[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