Ubuntu下搭建Git服务器,并同步部署到服务器上

0.282字数 1907阅读 440

一、安装git服务器所需软件

终端输入以下命令:

lzn@lzn-ThinkPad-E420:~$ sudo apt-get install git-core openssh-server openssh-client  python-setuptools  

lzn@lzn-ThinkPad-E420:~$ sudo apt-get install git-core openssh-server openssh-client  python-setuptools

git-core: git核心软件;

openssh-server和openssh-client:git通过ssh协议在服务器与客户端之间进行数据传输;

python-setuptools:gitosis依赖;

接下来准备安装gitosis

安装gitosis之前需要初始化服务器的git用户信息,这个随便填。

lzn@lzn-ThinkPad-E420:~$ git config --global user.name "myname"     

lzn@lzn-ThinkPad-E420:~$ git config --global user.email "******@gmail.com"  

lzn@lzn-ThinkPad-E420:~$ git config --global user.name "myname" 

lzn@lzn-ThinkPad-E420:~$ git config --global user.email "******@gmail.com"

安装gitosis.gitosis主要是给用户授权.通过以下命令获取gitosis版本文件

ubuntu:~$ git clone https://github.com/res0nat0r/gitosis.git  

ubuntu:~$ git clone https://github.com/res0nat0r/gitosis.git

注意:中间有两个是数字零

获取gitosis文件后,进入到文件目录下面

ubuntu:~$ cd gitosis/    

ubuntu:~$ cd gitosis/ 

接着使用python命令安装目录下的setup.py的python脚本进行安装

ubuntu:~/gitosis$ sudo python setup.py install   

ubuntu:~/gitosis$ sudo python setup.py install

到这里,整个安装步骤就完成了,下面就开始对git进行一些基本的配置。

二、创建git管理员账户、配置git

创建一个账户(git)作为git服务器的管理员,可以管理其他用户的项目权限。

ubuntu:~/gitosis$ sudo useradd -m git    

ubuntu:~/gitosis$ sudo passwd git   

ubuntu:~/gitosis$ sudo useradd -m git 

ubuntu:~/gitosis$ sudo passwd git

然后再/home目录下创建一个项目仓库存储点,并设置只有git用户拥有所有权限,其他用户没有任何权限

ubuntu:/tmp/gitosis$ sudo mkdir /home/gitrepository    

ubuntu:/tmp/gitosis$ sudo chown git:git /home/gitrepository/    

ubuntu:/tmp/gitosis$ sudo chmod 700 /home/gitrepository/   

ubuntu:/tmp/gitosis$ sudo mkdir /home/gitrepository 

ubuntu:/tmp/gitosis$ sudo chown git:git /home/gitrepository/ 

ubuntu:/tmp/gitosis$ sudo chmod 700 /home/gitrepository/

由于gitosis默认状态下会将仓库放在用户的repositories目录下,例如git用户的仓库地址默认在

/home/git/repositories/目录下,这里我们需要创建一个链接映射。让他指向我们前面创建的专门用于存放项目的仓库目录/home/gitrepository。

lzn@lzn-ThinkPad-E420:~$ su - git  

git@lzn-ThinkPad-E420:~$ sudo ln -s /home/gitrepository /home/git/repositories    

lzn@lzn-ThinkPad-E420:~$ su - git

git@lzn-ThinkPad-E420:~$ sudo ln -s /home/gitrepository /home/git/repositories 

这里我将在服务器端生成ssh公钥,如果想在其他机器上管理也可以在其他机器上生成一个ssh的公钥。

git@lzn-ThinkPad-E420:~$ ssh-keygen -t rsa    

git@lzn-ThinkPad-E420:~$ ssh-keygen -t rsa 

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

然后用刚生成公钥id_rsa.pub来对gitosis进行初始化。

git@lzn-ThinkPad-E420:~$ gitosis-init < ~/.ssh/id_rsa.pub  

git@lzn-ThinkPad-E420:~$ gitosis-init < ~/.ssh/id_rsa.pub


出现如上信息说明gitosis已经初始化成功。

gitosis主要是通过gitosis-admin.git仓库来管理一些配置文件的,如用户权限的管理。这里我们需要对其中的一

个post-update文件添加可执行的权限。

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

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

三、服务器上创建项目仓库

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

ubuntu:/home/git$ su - git    

ubuntu:/home/git$ cd /home/gitrepository    

ubuntu:/home/git/repositories$ mkdir mytestproject.git    

ubuntu:/home/git/repositories$ cd mytestproject.git    

ubuntu:/home/gitrepositories/mytestproject$ git init --bare   

新建的这个仓库暂时还是空的,不能被客户端clone,还需要对gitosis进行一些配置操作。

四、使用gitosis管理用户操作项目的权限

首先需要在前面生成ssh公钥(用来初始化gitosis)的机器上将gitosis-admin.git的仓库clone下来。

在客户端机器上新建一个目录用于存放gitosis-admin.git仓库

ubuntu:~$ mkdir gitadmin    

ubuntu:~$ cd gitadmin/    

ubuntu:~/gitadmin$ git clone git@192.168.1.106:repositories/gitosis-admin.git   

    ubuntu:~$ mkdir gitadmin 

    ubuntu:~$ cd gitadmin/ 

    ubuntu:~/gitadmin$ git clone git@192.168.1.106:repositories/gitosis-admin.git

clone正确会显示一下信息


clone下来会有一个gitosis.conf的配置文件和一个keydir的目录。gitosis.conf用于配置用户的权限信息,

keydir主要用户存放ssh公钥文件(一般以“用户名.pub”命名,gitosis.conf配置文件中需使用相同用户名),用

于认证请求的客户端机器。

现在让需要授权的用户使用前面的方式各自在其自己的机器上生成相应的ssh公钥文件,管理员把他们分别按用户名

命名好,复制到keydir目录下。

ubuntu:~$ cp /home/aaaaa/Desktop/zhangsan.pub /home/aaaaa/gitadmin/gitosis-admin/keydir/    

ubuntu:~$ cp /home/aaaaa/Desktop/lisi.pub /home/aaaaa/gitadmin/gitosis-admin/keydir/    

    ubuntu:~$ cp /home/aaaaa/Desktop/zhangsan.pub /home/aaaaa/gitadmin/gitosis-admin/keydir/ 

    ubuntu:~$ cp /home/aaaaa/Desktop/lisi.pub /home/aaaaa/gitadmin/gitosis-admin/keydir/ 

继续编辑gitosis.conf文件

[gitosis]

[group gitosis-admin]

####管理员组

members = charn@ubuntu

####管理员用户名,需要在keydir目录下找到相应的.pub文件,多个可用空格隔开(

下同)

writable = gitosis-admin

####可写的项目仓库名,多个可用空格隔开(下同)

[group testwrite]

####可写权限组

members =

zhangsan####组用户

writable = mytestproject

####可写的项目仓库名

[group testread]####只读权限组members =lisi####组用户readonly= mytestproject####只读项目仓库名

因为这些配置的修改只是在本地修改的,还需要推送到服务器中才能生效。

ubuntu:~/gitadmin/gitosis-admin$ git add .    

ubuntu:~/gitadmin/gitosis-admin$ git commit -am "add a user permission"    

ubuntu:~/gitadmin/gitosis-admin$ git push origin master    

    ubuntu:~/gitadmin/gitosis-admin$ git add . 

    ubuntu:~/gitadmin/gitosis-admin$ git commit -am "add a user permission" 

    ubuntu:~/gitadmin/gitosis-admin$ git push origin master 

推送成功会显示下面提示信息


新增的用户不能立即生效,这时候需要重新启动一下sshd服务

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

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

现在,服务端的git就已经安装和配置完成了,接下来就需要有权限的组成员在各自的机器上clone服务器上的相应

项目仓库进行相应的工作了。

五、客户端(linux)使用git

在终端执行如下命令:

$ mkdir testgit    

$ cd testgit    

$ git init    

$ echo "this is a test text file,will push to server"> hello.txt    

$ git add .    

$ git commit -am "init a base version,add a first file for push to server"    

$ git remote add origin git@serverip:repositories/mytestproject.git    

$ git push origin master   

    $ mkdir testgit 

    $ cd testgit 

    $ git init 

    $ echo "this is a test text file,will push to server" > hello.txt 

    $ git add . 

    $ git commit -am "init a base version,add a first file for push to server" 

    $ git remote add origin git@serverip:repositories/mytestproject.git 

    $ git push origin master

这样服务端就创建好了一个mytestproject.git的仓库的基础版本了,现在其他组员只要从服务端进行clone就可以

了。

添加了相关权限的用户可以执行如下命令:

$ git clone git@serverip:repositories/mytestproject.git    

    $ git clone git@serverip:repositories/mytestproject.git 

就可以把项目clone到本地仓库了。

下面进行简单的修改和提交操作

$ cd mytestproject    

$ echo "this is another text file created by other">another.txt    

$ git add .    

$ git commit -am "add a another file by other"    

$ git push origin master    

六、通过hooks部署代码到服务器

进入项目

# cd /home/www/project.git/hooks

# vim post-receive

#!/bin/sh

#PATH=$PATH:/usr/local/python27/binGIT_WORK_TREE=/home/www/newproject git checkout -f

cd/home/www/newproject && make html >/dev/null 2>&1

cd/home/www/newproject && make html >/dev/null 2>&1

然后将post-receive改为可执行,更改文件所有者

chmod +x post-receive

chown git:git -R /home/www/newproject

感谢http://blog.csdn.net/iron_lzn/article/details/53009733

感谢https://www.jianshu.com/p/5c7ce1b02100