android很流行,它的开发环境也很流行。下面我们参照它的模式,搭建一个企业内部的完整版本管理系统。
基本概念:
Git是目前最流行的分布式版本管理工具,当然它提供了其他版本管理工具都有的功能,同时提供了轻量级的分支管理,非常的实用。看前面的句子,注意到没有,它是分布式的,所以那里都有一份完整的代码,不用担心服务器被破坏,当然国际品牌,速度相当的快。
Gitosis 这个是权限管理工具。因为我们需要跟很多的人合作,每个人我们都希望给予他不同的权限,这样就不怕重要的项目被不重要的人看到了。
Repo算是一个助手吧,以为当Git的Repositery很多的时候,一个一个的使用git命令,相对的麻烦,特别是android有200个Repos时,更加麻烦了。因此谷歌用python写了这个脚本,方便大家使用嘛,一切是效率优先。
安装过程:
这哥们写得不错,我做一定的补充吧
1、ubuntu服务器安装git
sudo apt-get install git-core
输入git命令看看工作正常不,如果你的工作机器也是ubuntu,同样使用这个命令安装。
2、客户端安装git
如果你的是ubuntu 就跟第一步一样。如果是windows,到这个地址下载可执行文件,然后一步一步确定。安装完毕后,再cmd里面看看git这个命令工作正常不,如果不正常,就要配置一下环境变量
3、服务器上上安装Gitosis程序
sudo apt-get install python-setuptools // 因为使用了python脚本
mkdir ~/src //创建一个工作目录
cd ~/src
git clone git://eagain.net/gitosis.git //下载代码
cd gitosis
sudo python setup.py install //使用脚本进行安装
安装后,它的一些命令就可以使用了。gitosis-init gitosis-run-hook gitosis-serve,后面我们会使用gitosis-init来初始化数据。
4、服务器上创建一个git帐号
sudo adduser \
--system \
--shell /bin/sh \
--gecos 'git version control' \
--group \
--disabled-password \
--home /home/git \
git
通过sudo adduser 也是可以的。有图形界面也可以用来创建
5、客户端创建ssh 密钥对
sudo apt-get install openssh-client
ssh-keygen
按照提示输入。这样在~/.ssh目录下就可以看到生成的东西了。这个密钥是非对称的,使用了RSA的非对称算法,
superuser@linux-server:~/.ssh$ ls
id_rsa id_rsa.pub known_hosts
id_rsa 是私钥,是自己放好的,千万不要给人家知道。而id_rsa.pub是分发给别人的。别人可以用来加解密。
所以,我们要把这个id_rsa.pub上传到服务器,可以使用scp命令。例如:scp ~/.ssh/id_rsa.pub [email protected]:/tmp/
6、服务器端初始化gitosis
sudo -H -u git gitosis-init < /tmp/id_rsa.pub
这个的用意是,使用你提供的这个 id_rsa.pub公钥,创建一个gitosis_admin.git的reposi,执行这个语句时,输出的结果
Initialized empty Git repository in /home/git/repositories/gitosis-admin.git/
Reinitialized existing Git repository in /home/git/repositories/gitosis-admin.git/
会告诉你,这个gitosis_admin.git所在的位置,如果你的git帐号创建正确的话,那应该就在/home/git/repositories/gitosis_admin.git。
cd 到/home/git/repositories/gitosis-admin.git/gitosis-export 你可以看到一个[email protected]的文件,这个就是上面的id_rsa.pub的副本。
vim/home/git//repositories/gitosis-admin.git/gitosis.conf 可以看到,
[group gitosis-admin]
writable = gitosis-admin
members = yzchen@linux-server
这就表示,yzchen@linux-server 拥有管理这个gitosis-admin的权限。
这里需要明白的,yzchen@linux-server这个名字是随便定义的,只要跟你的.pub文件名一致即可,因为整个匹配的过程是,客户端请求是用自己的私钥加密了内容,gitosis在gitosis-export这里面循环测试找到对应的*.pub的公钥,然后就以这个公钥的文件名来对应gitosis.conf配置的members。因此公钥的文件名一定要跟你写的members一致,才可以起到作用。(这个文件名跟你的系统帐号没有任何关系)
7、修改gitosis的属性
sudo chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update
这一步是为了使得这个文件具有执行的权限。这一步可能不需要做,可以到后面遇到问题在回来做这一步
8、修改权限配置
到客户端去clone下来gitosis_admin,进行修改。你的客户端有这个权限去clone,是因为第6步你把客户端的密钥给他初始化了。如果你想给你的下面的项目管理也拥有这个管理权限,那就按照下面的步骤来。
git clone git@your server id:gitosis_admin.git
注意,这里,你不需要把git的路径写成:git@your server id:/home/git/repositories/gitosis-admin.git 这样的话gitosis 就会判断出错的。
clone下来后就按照6步上面提到的方法来修改。
例如我要添加 andrew 来管理项目。我叫andrew 通过第5步生成密钥对,然后发过来给我。我就把他命名为andrew_pm.pub,copy到gitosis-admin/keydir这个目录里。
然后把gitosis.conf修改为
[group gitosis-admin]
writable = gitosis-admin
members = yzchen@linux-server andrew_pm
记住啦,members 添加的 andrew_pm 要跟你命名的andrew_pm.pub一致
然后
git add .
git commit -m "add andrew for gitosis admin"
git push origin master
现在你到git账户下的gitosis-admin.git下面看看是否真的改变了。如果/home/git/repositories/gitosis-admin.git/gitosis-export 下面没有你增加的andrew_pm.pub 那你就要执行一下第6步。执行完了,再次commit 和 push
确定上面的步骤正确,那andrew同学就可以clone 这个gitosis_admin.git了。
同理,你也可以增加自己的git项目和设置权限。
搭建自己的repo
首先repo是要管理几个git的,我们先创建两个git, bootable.git binoic.git
git的管理需要一个manifests.git来规划。
manifests.git 里面会有一个default.xml的文件。这里面配置来的工程的信息。比如
fetch="[email protected]:testrepo/" />
这里面的格式大家照这写吧。
构建好这个manifests后,repo到时会根据这上面的参数进行git的操作。比如上面的会做
git clone [email protected]:testrepo/bootable.git
分别做git push后。使用
repo init -u [email protected]:manifests.git -b master
repo sync
我使用官方的repo,不修改的,做repo sync 的时候会出错。我使用了一个公司比较老的版本。
我的另外一篇文章写了 构建自己的repo.git欢迎参考
参考资料
https://wiki.archlinux.org/index.php/Gitosis
http://wiki.dreamhost.com/Gitosis
http://blog.agdunn.net/?p=277
http://www.jiangmiao.org/blog/1600.html // 写得不错
http://www.omappedia.com/wiki/Android_Miscellaneous // 还没有搞明白