在centos 下安装配置基于gitosis 的git 服务

原文:http://blog.csdn.net/esinzhong/article/details/8018041

前言 这里我用的系统是centos 6.2,

在服务器上的准备工作(服务器IP为10.0.2.8 ):
1、安装 openssh服务器与客户端工具

[plain]  view plain copy
 
  1. $ sudo yum install openssh-server openssh-client  

 

 

2、创建个人公钥和私钥(用于后面的git服务的管理员管理)
在默认用户的主目录路径下,运行以下命令,按照提示创建公钥和私钥

[plain]  view plain copy
 
  1. $ ssh-keygen -t rsa  

默认生成2048位,如果需要提高安全级别,也可以通过下面的命令创建公钥和私钥

 

[html]  view plain copy
 
  1. ssh-keygen -t rsa -b 4096  

默认情况下,公钥和私钥会保存在~/.ssh目录下,如下所示:


 

 

 

3、安装 git服务器

 

[plain]  view plain copy
 
  1. $  sudo yum install git-core  


4、配置 git服务器
创建git服务器管理用户

 

 

[plain]  view plain copy
 
  1. $  sudo useradd -m git   
  2. $  sudo passwd git  

创建git仓库存储目录

 

 

[plain]  view plain copy
 
  1. $  sudo mkdir /home/git/repositories  

设置git仓库权限

 

 

[plain]  view plain copy
 
  1. $  sudo chown git:git /home/git/repositories   
  2. $  sudo chmod 755 /home/git/repositories  


初始化全局设置

 

 

[plain]  view plain copy
 
  1. $  git config --global user.name "myname"   
  2. $  git config --global user.email "myname@server"  



5、安装python的setup tool 

 

 

[plain]  view plain copy
 
  1. $  sudo yum install python-setuptools  


6、获取并安装gitosis

 

 

[plain]  view plain copy
 
  1. $  cd /tmp   
  2. $  git clone git://eagain.net/gitosis.git //测试时从这拿不到,可换成 git clone https://github.com/res0nat0r/gitosis.git    
  3. $  cd gitosis   
  4. $  sudo python setup.py install  

 

 

7、配置gitosis

 

[plain]  view plain copy
 
  1. $  cp ~/.ssh/id_rsa.pub /tmp //上面第2步生成的公匙  
  2. $  sudo -H -u git gitosis-init < /tmp/id_rsa.pub //将该公匙导入gitosis里,这时本机已经有了为git的管理权限了  
  3. $  sudo chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update  

为了git操作时不用输入密码,还要做以下配置

 

 

[plain]  view plain copy
 
  1. $  cat /tmp/id_dsa.pub >> /home/git/.ssh/authorized_keys //将root的公匙导入到git目录的 authorized_keys文件中  
  2. $  chmod 600 /home/git/.ssh/authorized_keys  
  3.    

 

8、管理gitosis配置

 

[plain]  view plain copy
 
  1. $ cd ~   
  2. $ git clone git@hostname:/gitosis-admin.git   
  3. $ cd gitosis-admin/  
  4. $ ls -al  

看到以下结果


 

gitosis.conf是git仓库与权限配文件,keydir目录是存放其它客户机的公匙目录。

 

[plain]  view plain copy
 
  1. $  more gitosis.conf  

gitosis.conf 对应的内容

[plain]  view plain copy
 
  1. [gitosis]  
  2.   
  3. [group gitosis-admin]  
  4. writable = gitosis-admin  
  5. members = [email protected]  


来这里git的服务已基本配置完毕,但要团队开发中用起来还要进以下配置:

 

在成员机(ip=10.0.2.100)上操上面第1与第2步生成自已的公匙,

[html]  view plain copy
 
  1. $  scp .ssh/id_rsa.pub [email protected]:~/gitosis-admin/keydir/tester.pub //将本机的公匙copy到gitosis的keydir中  


再切换到git服务上(ip=10.0.2.8)

[plain]  view plain copy
 
  1. $  cd ~  
  2. $  cd gitosis-admin  
  3. $  cat keydir/tester.pub >> /home/git/.ssh/authorized_keys //将tester的公匙导入到git目录的 authorized_keys文件中  
  4. $ vi gitosis.conf  

修改gitosis.conf

[plain]  view plain copy
 
  1. [gitosis]  
  2. [group gitosis-admin]  
  3. writable = gitosis-admin  
  4. members = [email protected]  
  5. #加一个组myteam  
  6. [group myteam]  
  7. members = tester #这里的tester对上面公匙文件名  
  8. writable = test_project #项目仓库名  

提交到版本库

[plain]  view plain copy
 
  1. $ git add keydir/tester.pub  
  2. $ git commit -a -m "Allow tester write access to test_project"  
  3. $ git push origin master  

 

这时tester便有权限操作test_project仓库了,回到成员机(ip=10.0.2.100)上

 

[plain]  view plain copy
 
  1. $ cd ~  
  2. $ mkdir test_project  
  3. $ cd test_project  
  4. $ echo "testing ">test.txt  
  5. $ git init //初始化本地版本  
  6. $ git remote add origin [email protected]:test_project.git //加到远程版本库中  
  7. $ git add .  
  8. $ git commit -a -m "哈哈哈,测试一下"   
  9. $ git push origin master  

 

 

换个目录看能否clone回来

[plain]  view plain copy
 
  1. $ cd /tmp  
  2. $ git clone [email protected]:test_project.git //此时应该不会提示输入ssh密码的  

 

最后大功告成...

猜你喜欢

转载自aigo.iteye.com/blog/2025500