您的位置:首页 > 运维架构 > Nginx

Ubuntu16.04 下搭建git服务器及gitweb+nginx配置

2018-02-28 00:21 513 查看

本文转自:http://blog.csdn.net/water_horse/article/details/68958140

 

1.安装所需软件

fengjk@water:~$ sudo apt-get install git openssh-server openssh-client

 

2.创建git用户来管理git服务器

fengjk@water:~$ sudo useradd -m git
fengjk@water:~$ sudo passwd git

注意:加 -m 参数可以自动在/home 下创建用户目录,我这小白第一次就被坑了,没有自动创建git目录后面的步骤一脸茫然,最后忍痛重来。并且不用切换到git用户做下面操作

 

3.创建一个目录作为git仓库的存储点

fengjk@water:~$ sudo mkdir /home/git_pro
fengjk@water:~$ sudo chown git:git /home/git_pro/
fengjk@water:~$ sudo chmod 755 /home/git_pro/

这里的存储点就随便在哪创建和命名了,将该仓库权限交给git并将权限设置为 drwxr-xr-x

 

4.安装配置gitosis(用来添加使用git的用户和设定权限)

安装gitosis之前需要初始化一下git用户信息,这些信息可以比较随意些

fengjk@water:~$ git config --global user.name 'waterhorse'
fengjk@water:~$ git config --global user.email 'water@126.com'

也可以通过  fengjk@water:~$ cat ~/.gitconfig  来查看设置的信息,设置成功的显示结果为:

[user]
name = waterhorse
email = water@126.com

Gitosis 的工作依赖于某些 Python 工具,所以首先要安装 Python 的 setuptools 包,在 Ubuntu 上称为 python-setuptools:

fengjk@water:~$ sudo apt-get install python-setuptools

接下来,从 Gitosis 项目主页克隆并安装:

fengjk@water:~$ git clone https://github.com/res0nat0r/gitosis.git
fengjk@water:~$ cd gitosis/
fengjk@water:~/gitosis$ sudo python setup.py install

由于gitosis默认状态下会将仓库放在用户的repositories目录下,例如git用户的仓库地址默认在/home/git/repositories/目录下,这里我们需要创建一个链接映射。让他指向我们前面创建的专门用于存放项目的仓库目录/home/git_pro, 先切换成git用户

fengjk@water:~/gitosis$ su git
git@water:/home/fengjk/gitosis$ ln -s /home/git_pro /home/git/repositories
git@water:/home/fengjk/gitosis$ exit

成为管理员:无论是不是本机都可以通过生成ssh公钥的方法成为管理员 

fengjk@water:~/gitosis$ ssh-keygen -t rsa

生成的密钥可以在 ~/.ssh 里,查看   fengjk@water:~/gitosis$ ls ~/.ssh/

在服务器上建管理员 
首先要把公钥权限改为所有用户可读取: 

fengjk@water:~$ sudo chmod a+r ~/.ssh/id_rsa.pub

 现在可以初始化 Gitosis 了。你可以用自己的公钥执行 gitosis-init 命令,要是公钥不在服务器上,先临时复制一份:

fengjk@water:~/gitosis$ sudo -H -u git gitosis-init < ~/.ssh/id_rsa.pub
重新初始化现存的 Git 仓库于 /home/git_pro/gitosis-admin.git/
重新初始化现存的 Git 仓库于 /home/git_pro/gitosis-admin.git/

这样该公钥的拥有者就能修改用于配置 Gitosis 的那个特殊 Git 仓库了。接下来,需要手工对该仓库中的 post-update 脚本加上可执行权限:

fengjk@water:~/gitosis$ sudo chmod 755 /home/git_pro/gitosis-admin.git/hooks/post-update

 

 5.配置gitosis 

 Gitosis管理是通过一个特殊的 Git 仓库来管理,所以现在就克隆一个git库

fengjk@water:~$ mkdir myproject
fengjk@water:~$ cd myproject/
fengjk@water:~/myproject$ git clone git@xxx.xxx.xxx.xxx(注:ip地址):gitosis-admin.git
fengjk@water:~/myproject$ ll gitosis-admin/
总用量 20
drwxrwxr-x 4 fengjk fengjk 4096 4月   3 10:37 ./
drwxrwxr-x 3 fengjk fengjk 4096 4月   3 10:37 ../
drwxrwxr-x 8 fengjk fengjk 4096 4月   3 10:37 .git/
-rw-rw-r-- 1 fengjk fengjk   82 4月   3 10:37 gitosis.conf
drwxrwxr-x 2 fengjk fengjk 4096 4月   3 10:37 keydir/

 gitosis.conf 文件是用来设置用户、仓库和权限的控制文件。keydir 目录则是保存所有具有访问权限用户公钥的地方— 每人一个

 

 6.测试git 

 首先可以在本地创建一个git库

fengjk@water:~/myproject$ mkdir testpro
fengjk@water:~/myproject$ cd testpro/
fengjk@water:~/myproject/testpro$ git init
初始化空的 Git 仓库于 /home/fengjk/myproject/testpro/.git/
fengjk@water:~/myproject/testpro$ touch 1.txt
fengjk@water:~/myproject/testpro$ git add 1.txt
fengjk@water:~/myproject/testpro$ git commit -m '测试git'
[master (根提交) f7f62fc] 测试git
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 1.txt
fengjk@water:~/myproject/testpro$ git remote add origin git@xxx.xxx.xxx.xxx:testpro.git
fengjk@water:~/myproject/testpro$ git push origin master
ERROR:gitosis.serve.main:Repository read access denied
fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.

发现报错了,这是因为还没有权限使用这个仓库,这时就需要操作gitosis来添加用户对该仓库的权限了。 
将用户的公钥放到/home/fengjk/myproject/gitosis-admin/keydir目录下:

fengjk@water:~/myproject/testpro$ cp ~/.ssh/id_rsa.pub /home/fengjk/myproject/gitosis-admin/keydir/fengjk@water.pub

再对gitosis.conf进行配置

fengjk@water:~/myproject/testpro$ sudo vi /home/fengjk/myproject/gitosis-admin/gitosis.conf

在文件里添加下面一段代码

[group test]            ####这个test可以随意命名
members = fengjk@water  ####用户名
writable = testpro      ####项目仓库名

最后保存,需要推送

fengjk@water:~/myproject/testpro$ cd /home/fengjk/myproject/gitosis-admin/
fengjk@water:~/myproject/gitosis-admin$ git add .
fengjk@water:~/myproject/gitosis-admin$ git commit -m '添加仓库权限'[master bb732da] 添加仓库权限
1 file changed, 1 insertion(+)
fengjk@water:~/myproject/gitosis-admin$ git push origin master

然后在进入到testpro目录进行推送

fengjk@water:~/myproject/gitosis-admin$ cd /home/fengjk/myproject/testpro/
fengjk@water:~/myproject/testpro$ git push origin master
初始化空的 Git 仓库于 /home/git_pro/testpro.git/
对象计数中: 3, 完成.
写入对象中: 100% (3/3), 207 bytes | 0 bytes/s, 完成.
Total 3 (delta 0), reused 0 (delta 0)
To git@202.199.70.191:testpro.git
* [new branch]      master -> master

成功了!再到git_pro仓库存储目录下查看就有了刚刚的testpro仓库了:

fengjk@water:~/myproject/testpro$ cd /home/git_pro/
fengjk@water:/home/git_pro$ ls
gitosis-admin.git  testpro.git

 

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: