本文转自: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:~$ /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@.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$ /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/ 总用量 drwxrwxr-x fengjk fengjk 4月 : ./ drwxrwxr-x fengjk fengjk 4月 : ../ drwxrwxr-x fengjk fengjk 4月 : .git/ -rw-rw-r-- fengjk fengjk 4月 : gitosis.conf drwxrwxr-x fengjk fengjk 4月 : 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$ .txt fengjk@water:~/myproject/testpro$ git add .txt fengjk@water:~/myproject/testpro$ git commit -m '测试git' [master (根提交) f7f62fc] 测试git insertions(+), deletions(-) create mode .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] 添加仓库权限 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/ 对象计数中: , 完成. 写入对象中: % (/), bytes | bytes/s, 完成. Total (delta ), reused (delta ) 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