Ubuntu16.04服务器 搭建Git 服务

 

一.安装Git服务器所需软件

1.安装git-core, openssh-server, openssh-client三个软件。git-core是git的核心软件; openssh-server、openssh-client是服务器和客户端传输文件通过ssh协议。

输入:sudo apt-get install git-core openssh-server openssh-client

 

 

2. 初始化git服务器用户信息。

输入:git config --global user.name ”Tyche***”

           git config --global user.email ”8057*****@qq.com”

 

 

3. 安装python-setuptools软件。

输入:sudo apt-get install python-setuptools

 

 

4.安装gitosis。Gitosis主要用于管理用户对仓库的操作权限。

安装:git clone https://github.com/res0nat0r/gitosis.git

进入gitosis目录:  cd gitosis/

使用安装目录下的setup.py的脚本安装。输入:sudo python setup.py install

 

 

二.配置Git服务器

1.创建git管理员账户

增加用户命令:sudo useradd  -m  git

修改git用户密码:sudo passwd git

 

 

 2. 初始化gitosis

在服务端生成SSH公钥,输入命令:ssh-keygen -t rsa

这里会提示输入密码,直接回车即可。

 

 

用刚生成公钥id_rsa.pub来对gitosis进行初始化。输入命令:sudo -H -u git gitosis-init <  /root/.ssh/id_rsa.pub

 

 

 3. 添加git用户对文件夹的权限

输入: sudo chown git:git /home/git/repositories

            sudo chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update

            sudo chmod 755 /home/git/repositories

 

三.创建项目仓库

使用git账户在服务器上创建一个目录(mytestproject.git)并初始化成git项目仓库。

ubuntu:/home/git$ su git
~git$ cd /home/git/repositories
~git$ mkdir mytestproject.git

~git$ cd mytestproject.git/
~git$ git init --bare

 

四. gitosis管理用户操作权限

1. 首先需要一个管理员客户端,使用前面生成ssh公钥(用来初始化gitosis)的机器上将gitosis-admin.git的仓库clone下来。在管理员客户端机器上新建一个目录用于存放gitosis-admin.git仓库

 

 

clone时不能用绝对路径,只能写相对于git用户home的相对路径
错误:git@xxx.xxx.xxx.xxx:gitosis-admin.git
正确:git@xxx.xxx.xxx.xxx:/home/git/repositories/gitosis-admin.git

 输入 :sudo clone git@xxx.xxx.xxx.xxx:/home/git/repositories/gitosis-admin.git

clone下来的gitosis-admin文件夹有一个gitosis.conf的配置文件和一个keydir的目录。keydir主要用户存放ssh公钥文件(一般以“用户名.pub”命名,gitosis.conf配置文件中需使用相同用户名),用于认证请求,gitosis.conf用于配置用户的权限。

 

 

1. 现在需要将授权的用户在自己的机器上生成相应的ssh公钥,  打开git bush并输入:ssh-keygen -t rsa -C “email@example.com”

2. 将生成的公钥文件一般在  C:/用户/自己的用户名/.ssh 下的 id_rsa.pub

3. 管理员收集这些文件,分别按用户名命名好,复制到刚才的keydir目录下。

4. 编辑gitosis.conf文件管理用户权限

[gitosis]

[group gitosis-admin]      #管理员
members = charn@ubuntu #管理员用户名,需要在keydir目录下找到相应的.pub文件,多个管理员用空格隔开writable = gitosis-admin   #可写的项目仓库名,多个仓库用空格隔开

 

[group testwrite]           #建一个组:可写权限
members = abc            #用户
writable = mytestproject   #可写的项目仓库名

 

[group testread]           #建一个组:只读权限
members =def             #用户
readonly= mytestproject   #只读的项目仓库名

 

本地修改完配置后,还需要推送到服务器才能生效。

ubuntu:~/gitadmin/gitosis-admin$ git add .
ubuntu:~/gitadmin/gitosis-admin$ git commit -am "add users"
ubuntu:~/gitadmin/gitosis-admin$ git push origin master

 

还需要在服务端重新启动一下sshd服务

ubuntu:~/gitadmin/gitosis-admin$ sudo /etc/init.d/ssh restart

服务端的git就已经安装和配置完成了,接下来就需要有权限的组成员在各自的机器上clone服务器上的相应项目仓库进行相应的工作了。

 

五.在客户端测试

1. 在本地新建一个mytestproject文件夹

2. 将空项目clone下来,输入 : git clone git@62.234.***.***:mytestproject.git

 

 

3. 本地添加一个log.txt 文件

 

4. 然后将添加的文件提交,输入:

git  add .

git  commit  –m  "add a log.txt"

git push origin master

 

 5. 检查git历史状态

 

ok !

 

posted @ 2018-11-29 12:50  漆天初晓  阅读(275)  评论(0编辑  收藏  举报