您的位置:首页 > 其它

git 服务器搭建,使用gitosis

2015-04-21 17:24 423 查看


装载:http://blog.csdn.net/esinzhong/article/details/8018041

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

[plain] view plaincopy

1. $ sudo apt-get install openssh-server openssh-client  

 

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

[plain] view plaincopy

1. $ ssh-keygen -t rsa  

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

[html] view plaincopy

1. ssh-keygen -t rsa -b 4096  

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

 

3、安装 git服务器

[plain] view plaincopy

1. $  sudo apt-get install git-core  

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

[plain] view plaincopy

1. $  sudo useradd -m git   

2. $  sudo passwd git  
3. 

5. 创建git仓库存储目录

[plain] view plaincopy

1. $  sudo mkdir /home/git/repositories  

6. 设置git仓库权限

[plain] view plaincopy

1. $  sudo chown git:git /home/git/repositories   

2. $  sudo chmod 755 /home/git/repositories  

7. 
初始化全局设置

[plain] view plaincopy

1. $  git config --global user.name "myname"   

2. $  git config --global user.email "myname@server"  

8. 

5、安装python的setup tool 

[plain] view plaincopy

1. $  sudo apt-get install python-setuptools  

9. 
6、获取并安装gitosis

[plain] view plaincopy

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  
 

10. 7、配置gitosis

[plain] view plaincopy

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  

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

[plain] view plaincopy

1. $  cat /tmp/id_dsa.pub >> /home/git/.ssh/authorized_keys //将root的公匙导入到git目录的 authorized_keys文件中  

2. $  chmod 600 /home/git/.ssh/authorized_keys  
3.    

12.  

8、管理gitosis配置

[plain] view plaincopy

1. $ cd ~   

2. $ git clone git@hostname:/gitosis-admin.git   
3. $ cd gitosis-admin/  

4. $ ls -al  

13. 看到以下结果

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

[plain] view plaincopy

1. $  more gitosis.conf  

14. gitosis.conf 对应的内容

[plain] view plaincopy

1. [gitosis]  

2.   
3. [group gitosis-admin]  

4. writable = gitosis-admin  
5. members = root@localhost.localdomain  

 

[gitosis]

[group gitosis-admin]
writable = gitosis-admin
members = a@server usr@pc1

[group hello]
writable = teamwork
members = a@serverb

[group hello_ro]
readonly = teamwork
members = lz

这个配置文件表达了如下含义:gitosis-admin组成员有a, usr,该组对gitosis-admin仓库有读写权限;
team组有a,b两个成员,该组对teamwork仓库有读写权限;
team_ro组有lz一个成员,对teamwork仓库有只读权限。

 

 

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

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

[html] view plaincopy

1. $  scp .ssh/id_rsa.pub root@10.0.2.8:~/gitosis-admin/keydir/tester.pub //将本机的公匙copy到gitosis的keydir中  

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

[plain] view plaincopy

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 plaincopy

1. [gitosis]  

2. [group gitosis-admin]  
3. writable = gitosis-admin  

4. members = root@localhost.localdomain  
5. #加一个组myteam  

6. [group myteam]  
7. members = tester #这里的tester对上面公匙文件名  

8. writable = test_project #项目仓库名  
提交到版本库

[plain] view plaincopy

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 plaincopy

1. $ cd ~  

2. $ mkdir test_project  

3. $ cd test_project  

4. $ echo "testing ">test.txt  

5. $ git init //初始化本地版本  

6. $ git remote add origin git@10.0.2.8:test_project.git //加到远程版本库中   如果错了用 git remote rm origin 

7. $ git add .  

8. $ git commit -a -m "哈哈哈,测试一下"   

9. $ git push origin master  

 

换个目录看能否clone回来

[plain] view plaincopy

1. $ cd /tmp  

2. $ git clone git@10.0.2.8:test_project.git //此时应该不会提示输入ssh密码的  

 

 

home/git/repositories/gitosis-admin.git/

 =========================================

转载:http://blog.csdn.net/ice520301/article/details/6142503

git服务器搭建过程

参考网上资料搭建git服务器过程记录 如下:


需求


硬件需求:一台Ubuntu或者debian电脑(虚拟机),能通过网络访问到。


软件需求:git-core, gitosis, openssh-server, openssh-client, Apache2(Gitweb)


安装配置git服务器

安装git和openssh:
a@server:~$ sudo apt-get install git-core openssh-server openssh-client

新加用户git, 该用户将作为所有代码仓库和用户权限的管理者:
a@server:~$ sudo useradd -m git
a@server:~$ sudo passwd git
建立一个git仓库的存储点:
a@server:~$ sudo mkdir /home/repo
让除了git以外的用户对此目录无任何权限:
a@server:~$ sudo chown git:git /home/repo
a@server:~$ sudo chmod 700 /home/repo


安装配置gitosis

初始化一下服务器的git用户,这一步其实是为了安装gitosis做准备。在任何一 台机器上使用git,第一次必须要初始化一下:
a@server:~$ git config –global user.name “myname”
a@server:~$ git config –global user.email “myname@server “

安装一下python的setup tool, 这个也是为了gitosis做准备:
a@server:~$ sudo apt-get install python-setuptools

获得gitosis包:
a@server:~$ cd /tmp
a@server:/tmp$ git clone git://eagain.net/gitosis.git
a@server:/tmp$ cd gitosis
a@server:/tmp/gitosis$ sudo python setup.py install

切换到git用户下:
a@server:/tmp/gitosis$ su git
默认状态下,gitosis会将git仓库放在 git用户的home下,所以我们做一个链接到/home/repo

$ ln -s /home/repo /home/git/repositories
再次返回到默认用户

$ exit

如果你将作为git服务器的管理员,那么在你的电 脑上(另一台pc)生成ssh公钥:
usr@pc1:~$ ssh-keygen -t rsa

将公钥拷贝到服务器的/tmp下:
usr@pc1:~$ scp .ssh/id_rsa.pub git@<server>:/tmp
回到git服务器上
a@server:/tmp/gitosis$ sudo chmod a+r /tmp/id_rsa.pub

让gitosis运行起来:
a@server:/tmp/gitosis$ sudo -H -u git gitosis-init < /tmp/id_rsa.pub

Initialized empty Git repository in /home/repo/gitosis-admin.git/

Reinitialized existing Git repository in /home/repo/gitosis-admin.git/

gitosis的有趣之处在于,它通过一个git仓库来管理配置文件,仓库就放在了/home/repo/gitosis- admin.git。我们需要为一个文件加上可执行权限:
a@server:/home/git$ sudo passwd root
a@server:/home/git$ su
root@server:/home/git # cd repositories
root@server:/home/git/repositories # cd gitosis-admin.git/
root@server:/home/git/repositories/gitosis-admin.gi # sudo
chmod 755 /home/repo/gitosis-admin.git/hooks/post-update

root@server:/home/git/repositories/gitosis-admin.git #
exit
 


在服务器上新建一个测试项目仓库

我建了一个叫“teamwork”的仓库。

切换到git用户:

a@ubuntu:/home/git$ su - git

$ cd /home/prj_git

$ mkdir teamwork.git

$ cd teamwork.git

$ git init --bare

$ exit

但是,到目前为止,这只是一个空仓库,空仓库是不能clone下来的。为了能做clone,我们必须先让某个有权限的人放一个初始化的版本到仓库中。
所以,我们必须先修改一下gitosis-admin.

管理gitosis的配置文件

刚刚提到,gitosis本身的配置也是通过git来实现的。在你自己的开发机里,把gitosis-admin.git这个仓库clone下来,就可以以管理员的身份修改配置了。

在你的电脑里:
usr@pc1:~/work$ git clone git@<server>:gitosis-admin.git
如果出现:
fatal: '~/gitosis-admin.git' does not appear to be a git repository

fatal: The remote end hung up unexpectedly
改成:

usr@pc1:~/work$ sudo git clone git@<Server-IP>:/home/prj_git/gitosis-admin.git

usr@pc1:~/work$ cd gitosis-admin/
该目录下的keydir目录是用来存放所有需要访问git服务器的用户的ssh公钥:
各个用户按照前面提到的办法生成各自的ssh公钥文件后,把所有人的 ssh公钥文件都拿来,按名字命名一下,比如b.pub, lz.pub等,统统拷贝到keydir下:
usr@pc1:~/work/gitosis-admin$ su root
root@server:/home/a/work/gitosis-admin # cp /path/to/.ssh/id_rsa.pub ./keydir/b.pub 
root@server:/home/a/work/gitosis-admin # exit
修改gitosis.conf文件,我的配置大致如下:

[gitosis]
[group gitosis-admin]

writable = gitosis-admin

members = a@server usr@pc1
[group hello]

writable = teamwork

members = a@server b
[group hello_ro]

readonly = teamwork

members = lz

这个配置文件表达了如下含义:gitosis-admin组成员有a, usr,该组对gitosis-admin仓库有读写权限;

team组有a,b两个成员,该组对teamwork仓库有读写权限;

team_ro组有lz一个成员,对teamwork仓库有只读权限。

当然目前这些配置文件的修改只是在你的本地,你必须推送到远程的gitserver上才能真正生效。

加入新文件、提交并push到git服务器:
usr@pc1:~/work/gitosis-admin$ git add .
usr@pc1:~/work/gitosis-admin$ git commit -am “add teamweok prj and users”
usr@pc1:~/work/gitosis-admin$ git push origin master

初始化测试项目

好了,现在服务器就搭建完了,并且有一个空的项目teamwork在服务器上。接下来呢?当然是测试一下,空仓库是不能clone的,所以需要某一个有写权限的人初始 化一个版本。就我来做吧,以下是在客户端完成。
usr@pc1:~/work$ mkdir teamwork-ori
usr@pc1:~/work$ cd teamwork-ori/
usr@pc1:~/work/teamwork-ori$ git init
usr@pc1:~/work/teamwork-ori$ echo “/*add something*/” > hello
usr@pc1:~/work/teamwork-ori$ git add .
usr@pc1:~/work/teamwork-ori$ git commit -am “initial version”
usr@pc1:~/work/teamwork-ori$ git remote add origin git@<server>:teamwork.git 
usr@pc1:~/work/teamwork-ori$ git push origin master
到此为止teamwork已经有了一个版本了,team的其他成员只要先clone一下 teamwork仓库,就可以任意玩了。

usr@pc1:~/work/teamwork-ori$ su b

$ cd /home/b

$ git clone git@<server>:teamwork.git
$ cd teamwork

$ vim hello

$ git add .

$ git commit -am “b add”
$ git push origin master

$ exit

添加已有git项目

另外:如果你有一个现成的git仓库,想放到 gitserver上供team使用(比如你clone了一个官方的kernel仓库,想在内部使用它作为基础仓库),怎么办呢。

首先需要从你的工作仓库中得到一个纯仓库, 比如你的工作目录为~/kernel, 你想导出纯仓库到你的优盘里,然后拷贝到gitserver上去。

$ git clone –bare ~/kernel /media/udisk

然后就拿着优盘,交给gitserver的管理员,让他拷贝到/home/repo/下,同时需要配置 gitosis相关配置文件哦,这个就不用再说了吧。比如:下载ALSA库:

git clone git://android.git.kernel.org/platform/external/alsa-lib.git

git clone git://android.git.kernel.org/platform/external/alsa-utils.git
生成bare库

git clone –bare alsa-lib alsa-lib.git

git clone –bare alsa-utils alsa-utils.git

将bare 库移动到git服务器目录
cp alsa-lib.git /home/repo
注意变更所有者,以获取提交权限。
chown -R git alsa-lib.git
然后就O 了,呵呵.

配置gitweb

1. 安装gitweb  

   sudo apt-get install gitweb

 

2. 安装apache2

  sudo apt-get install apache2

 

3. 配置gitweb 

(1)默认没有 css 加载,把 gitweb 要用的静态文件连接到 DocumentRoot 下:
   cd /var/ www/ 
   sudo ln -s / usr/ share/ gitweb/* .

   (注意后面的点)

(2)修改配置:

   sudo vi /etc/ gitweb.conf

   将 $projectroot 改为gitosis-admin.git所在目录: /home/git/repositories

 (3)修改 /home/git/repositories权限,默认情况下,gitosis将 repositories权限设置为不可读的

    sudo chmod 777 -R /home/git/repositories

11.编辑apache2配置文件,建立web站点 (默认情况下可以忽略此步骤)

(1) 编辑apache2配置文件

    ubuntu中默认的web目录是/var/www,默认的cgi目录是 /usr/lib/cgi-bin/,安装完成gitweb后,gitweb的gitweb.cgi会自动放置

到该目录下。如果你的cgi路径不是默认的/usr/lib/cgi-bin/,需要将gitweb安装在/usr/lib/cgi-bin中的gitweb.cgi复制到原来配置

的cgi-bin路径,并修改apache的配置文件/etc/apache2/apache.conf:

    SetEnv  GITWEB_CONFIG   /etc/gitweb.conf

    gitweb.conf配置文件形如:(可自行修改,这里不做详细介绍)

<Directory "/srv/www/cgi-bin/gitweb">           

      Options FollowSymlinks ExecCGI          

      Allow from all                          

      AllowOverride all                       

      Order allow,deny                        

      <Files gitweb.cgi>

           SetHandler cgi-script

      </Files>                    

      RewriteEngine on

      RewriteCond %{REQUEST_FILENAME} !-f

      RewriteCond %{REQUEST_FILENAME} !-d

      RewriteRule ^.* /gitweb.cgi/$0 [L,PT]

</Directory>

(2)重新启动apache:sudo /etc/init.d/apache2 restart,访问http://localhost/cgi-bin/gitweb.cgi

 

<以下未经测试>

配 置web访问方式:
Apache常用命令:

a2dissite gitserver 禁用

a2ensite gitserver  使能

/etc/init.d/apache2 restart 重启
1.apt-get install apache2
2.手动安 装gitweb

git clone git://git.kernel.org/pub/scm/git/git.git

cd git

make GITWEB_PROJECTROOT=”/home/repo” prefix=/usr gitweb/gitweb.cgi

cd gitweb

cp -av git* /home/repo/
3.vim /etc/apache2/sites-available/gitserver

<VirtualHost 172.20.146.39:80>

ServerName 172.20.146.39

DocumentRoot /home/repo

ScriptAlias /cgi-bin/ /home/repo

<Directory /home/repo>

Options ExecCGI +FollowSymLinks +SymLinksIfOwnerMatch

AllowOverride All

order allow,deny

Allow from all

AddHandler cgi-script cgi

DirectoryIndex gitweb.cgi

</Directory>

</VirtualHost>
4.赋予权限,很重要:
chgrp -R www-data /home/repo

chmod a+r repo

chmod a+x repo
mv hooks/post-update.sample hooks/post-update
5.a2ensite gitserver

6./etc/init.d/apache2 restart
匿名访问方式:

git clone http://192.168.1.1/alsa-lib.git 

git clone http://192.168.1.1/alsa-utils.git 

git访问方式:

git clone git@192.168.1.1:alsa-lib.git 

Web网页浏览:
http://192.168.1.1
遇到的问题:

1.windows文件命名不区分大小 写,而linux支持。这样android源码下载时会出现一下问题。大约有15个文件存在这个问题。

2.库的描述文件在.git文件夹的description文件中。编辑该文件,在gitweb页中就会有 description。

3.gitosis库hooks下的post- update不是由post-update.sample重命名过来的,它们不一样。post-update可以更新工作目录,保持与库一致。没有它配置 文件是不会更新的。

4.(1)git@hello:/home/git$ git add .

error: readlink(“external/openssl/apps/md4.c”): No such file or directory

error: unable to index file external/openssl/apps/md4.c

fatal: adding files failed
(2)root@/external/openssl# git init

Initialized empty Git repository in /external/openssl/.git/
root@/external/openssl # git add .

error: readlink(“apps/md4.c”): No such file or directory

error: unable to index file apps/md4.c

fatal: adding files failed

(3) root@android-2.1_r2$ rm -Rf .repo
root@android-2.1_r2 find
. -name “.git” | xargs rm -Rf
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  git服务器