ubuntu搭建git服务器和心得体会

来源:互联网 发布:制作课件的软件 编辑:程序博客网 时间:2024/05/17 08:52


通过一翻谷歌和度娘,终于把git服务器成功搭建起来,这里简要记录下搭建的过程和自己搭建过程中的心得体会,以便日后查看,文章内容参考网络上大部分相关文章:(http://www.linuxidc.com/Linux/2011-05/35639p3.htm)

1、Git服务端

1.1.请使用apt-get update和apt-get upgrade命令更新当前系统,如果不更新,在后面安装一些程序的时候可能会出现某些依赖包没安装的现象。

1.2.安装OpenSSH Server( ubuntu) (当前用户为wirror800)

首先,使用ps -e|grep ssh命令,检查本机上是否已经运行ssh服务。如果没有,继续;否则,跳过此步骤。

执行命令:
sudo apt-get install openssh-server

1.3.修改ssh服务端配置文件 /etc/ssh/sshd_config
<pre lang="shell">
Port 22 # 修改成你想要的登陆端口,如1212

PermitRootLogin Yes # 允许root用户登陆,如果不允许,后面可能无法git clone project内容

StrictModes yes # 检查密钥的用户和权限是否正确,默认打开的

RSAAuthentication yes # 启用 RSA 认证

PubkeyAuthentication yes # 启用公钥认证

PasswordAuthentication Yes # 允许密码认证,如果不允许,后面可能无法git clone project内容

ServerKeyBits 1024 # 修改后变为此状态,将ServerKey强度改为1024比特

PermitEmptyPasswords no # 修改后变为此状态,禁止空密码进行登录

修改完成后,重启ssh服务:

sudo /etc/init.d/ssh restart

2、安装git和gitosis:

sudo apt-get install git-core gitosis

3、为gitosis创建用户

sudo useradd -m git //创建新用户并创建家目录

sudo password git

4、运行gitosis

scp ~/.ssh/id_rsa.pub wuxinxinggg@remothost:/home/wuxinxinggg //这里要注意的是一定要把管理员生成的id_rsa.pub放到git服务器操作的用户的家目录,比如我的是/home/wuxinxinggg/.ssh 否则将Permission denied (public)

5、初始化gitosis

cd /home/wuxinxinggg #切换到上传的id_rsa.pub目录下

sudo -H -u git gitosis-init < id_rsa.pub (或者切换到git用户下执行gitosis-init < id_rsa.pub也可以,记得exit切换回当前用户)

6、安装配置gitweb

安装gitweb
sudo apt-get install gitweb

安装apache2
<pre lang="shell">
sudo apt-get install apache2

配置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

编辑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配置文件形如:(可自行修改,这里不做详细介绍)


Options FollowSymlinks ExecCGI
Allow from all
AllowOverride all
Order allow,deny

SetHandler cgi-script

RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^.* /gitweb.cgi/$0 [L,PT]

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

7、git管理员客户端配置

生成密钥:ssh-keygen -t rsa

安装msysgit //安装过程保持默认

从服务器 克隆gitosis-admin.git

首先选定目录,如G盘:cd /g/

然后,新建一个目录mkdir gitproject

git clone git@YOUR_SERVER:gitosis-admin.git

( YOUR_SERVER可以是你的服务器名称或者ip,我这里的ubuntu的ip为192.168.1.102 )

编辑 gitosis.conf

cd gitosis-admin

你将看到以下文件gitosis.conf和keydir/,gitosis.conf是gitosis的配置文件,用于配置用户和权限,keydir/是所有组成员的

公钥。

vi gitosis.conf, 打开gitosis.conf文件,内容为:

[group gitosis-admin]
writable = gitosis-admin
members = Administrator@LILIN

这个是管理组的权限,members中的用户名就是刚才上传的公钥里面的用户名。

把内容修改为:

[gitosis]
gitweb = yes

[group gitosis-admin]
writable = gitosis-admin
members = Administrator@LILIN wirror800@192.168.1.102

[group apps ]
writable = apps
members = Administrator@LILIN wirror800@192.168.1.102

其中 gitweb = yes表示启用对gitweb的支持。 这里定义了一个叫apps的组,授予Administrator@LILIN和wirror800@192.168.1.102

两个用户写“apps ”这个repo的权限

然后push到服务端后,服务器端就立刻生效。

git commit -a -m “created a new repository”

git push

这样就 更新了服务端的权限。

创建一个app的repo

mkdir apps

cd apps

git init

创建、编辑 .gitignore , 用于忽略某些不需要进行代码管理的内容,如rails的应用可能如下:

.DS_Store
log/*.log
tmp/**/*
config/database.yml
db/*.sqlite3

编辑 .git/description 内容, 加上apps 的说明

提交代码

git remote add origin git@YOUR_SERVER:apps.git

git add .

git commit -am “imitial import”

git push origin master:refs/heads/master

增加成员的公钥到系统中

cd ../gitosis-admin

cp member_1.pub keydir/

cp member_2.pub keydir/ git

add keydir/member_1.pub keydir/member_2.pub

修改gitosis.conf,并提交

[group apps]
members = wirror800
members = wirror800 member_1 member_2
writable = apps

git commit -a -m “Granted new members commit rights to apps”
git push

其它成员获取apps的代码

git clone git@YOUR_SERVER:apps.git

wuxinxinggg使用总结:

1、上传代码到git服务器:

①修改gitosis-admin下的gitosis.conf,添加工程配置,如下所示:

[group git-test]
members = wuxinxinggg@wuxinxinggg.com //其中members的名要和gitosis-admin目录下的keydir目录中的key名对应上
writable = git-test //此处的git-test和上面group中的git-test一样,都是你上传代码的工程文件夹名

②在gitosis-admin同级目录下创建git-test目录,并将代码拷贝到该目录

③进入git-test,依次执行:
git init

git remote add origin git@host:git-test.git
git add . //此处的点别忘记了
git commit -a -m "www.wuxinxinggg.com" //其中www.wuxinxinggg.com为你上传代码的comment
git push origin master //或者 git push origin master:refs/heads/master

2、更新代码后push到git服务器流程:

更新代码后如果直接git push,系统会提示Everything Up-to-date,但是实际上服务器并没有做对应修改,所有必须要按照下面的流程走,以保证代码成功push到服务器

git add .
git commit -a -m "update something by www.wuxinxinggg.com"
git push

3、git服务器端clone和push工程代码

网上搜索关于git服务器既做服务器,同时做服务器代码的管理员,但是没有找到,今天在一篇博文上看到了,其实git服务器没有服务器端和客户端的说法,只是clone的时候要指明工程的详细路径罢了,如下所示:

"客户端"clone工程代码:

git clone git@wuxinxinggg.com:gitosis-admin.git

"服务器端"clone工程代码

git clone git@localhost:/home/git/repositories/gitosis-admin.git

4、git服务器clone非默认端口代码

git clone ssh://user@host:port/home/git/repositories/gitosis-admin.git

错误总结:
1、添加新项目代码到服务器报Repository read access denied

查看服务器上的gitosis-admin.git目录下的gitosis.conf是否软连接到repositories目录下的gitosis.conf文件,并查看其中的内容是否和客户端管理员的配置文件相同,如若不是,请按照上面的更新代码后push到git服务器流程重新更新gitosis-admin到服务器

转自:

http://www.wuxinxinggg.com/ubuntu%E6%90%AD%E5%BB%BAgit%E6%9C%8D%E5%8A%A1%E5%99%A8%E5%92%8C%E5%BF%83%E5%BE%97%E4%BD%93%E4%BC%9A

原创粉丝点击