版本控制系统(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服务器:
# cat /etc/redhat-release
CentOS Linux> # ifconfig |awk 'NR==2 {print $2}'
172.16.48.132
1. 安装相应的依赖环境
# yum install perl openssh git -y
2. 创建git用户,生成用于管理gitolite的公钥和私钥
# useradd git
# echo git|passwd --stdin git
# ssh-keygen
# cp /root/.ssh/id_rsa.pub /tmp/admin.pub
3. 切换到git用户下创建安装目录
# su - git
$ mkdir bin
4. 下载gitolite源码
$ git clone https://github.com/sitaramc/gitolite.git
5. 安装gitolite
$ ./gitolite/install -to /home/git/bin/
$ /home/git/bin/gitolite setup -pk /tmp/admin.pub
6. 切换到root用户下,clone gitolite-admin.git
$ su - root
# git clone git@172.16.48.132:gitolite-admin.git
7. 至此,成功clone下gitolite-admin目录即gitolite安装成功。
# ls
anaconda-ks.cfggitolite-admin
注:gitolite是通过管理gitolite-admin来对仓库进行授权管理的。
1. conf为配置文件目录
2. keydir为git客户端公钥目录
协作使用
开发人员1服务器配置:
# cat /etc/redhat-release
CentOS Linux> # ifconfig|awk 'NR==2 {print $2}'
172.16.48.129
1. 在开发人员1服务器上生成公钥私钥
# ssh-keygen -f ~/.ssh/chentaicheng
# ls ~/.ssh/
chentaichengchentaicheng.pub
2. 将公钥chentaicheng.pub存放到gitolite服务器的gitolite-admin/keydir目录下
# scp -P22 -r -p ~/.ssh/chentaicheng.pub root@172.16.48.132:gitolite-admin/keydir
3. 访问仓库配置文件
gitolite服务器上配置chentaicheng密钥对应的仓库及权限:
1. 检查chentaicehng.pub是否存在gitolite-admin/keydir目录下
# pwd
/root/gitolite-admin/keydir
# ls
admin.pubchentaicheng.pub
#
2. 配置chentaicheng密钥对应的仓库
3. 配置git
# pwd
/root/gitolite-admin
# git config --global user.email "chentaicheng@qq.com"
# git config --global user.name "chentaicheng"
4. 将修改后的配置及公钥更新到gitolite服务器
# git add *
# git commit -m 'add new repo ctc by chentaicheng'
# git push
检查开发人员1是否能获取仓库ctc的读写权限
Clone ctc仓库并增加内容然后提交到远程仓库上
# git clone gitolite:ctc
Cloning into 'ctc'...
Enter passphrase for key '/root/.ssh/chentaicheng':
warning: You appear to have cloned an empty repository.
# ls
anaconda-ks.cfgctc
# cd ctc/
# git config --global user.email "791582297@qq.com"
# git config --global user.name "CTC"
# git add readme.txt
# git commit -m 'add readme.txt'
# git push origin master
至此,git+gitolite部署完毕。
开发人员2获取开发人员1push的代码
开发人员2环境:
# cat /etc/redhat-release
CentOS Linux> # ifconfig|awk 'NR==2 {print $2}'
172.16.48.133
1. 在开发人员2主机上生成密钥对,并将密钥传输到gitolite服务的gitolite-admin/keydir目录下
# mkdir .ssh
# ssh-keygen -f .ssh/develop
# scp -P22 root@172.16.48.132:gitolite-admin/keydir
2. 配置develop密钥对应的仓库
3. gitolite修改配置文件,并更新到gitolite服务器上,使开发人员2对ctc仓库具有读写权限。
# pwd
/root/gitolite-admin
# git add *
# git commit -m 'add develop'
# git push
4. 开发人员2获取开发人员1push的代码
# git clone gitolite:ctc
# ls
anaconda-ks.cfgctc
# cd ctc/
# ls
readme.txt
页:
[1]