Ubuntu 14.04下搭建Git服务器

使用git可以简单的搭建Git服务器仓库,原理是使用ssh登录,这个方法的优点就是简单。

看了一些搭建Git服务器的教程,都不是很详细,于是,就有了本文→_→

使用步骤:

##1.安装git:

sudo apt-get install git

环境说明:

2.创建一个git用户,用来运行git服务:

sudo adduser git

本地:Win7      IP:192.168.111.1

3.创建证书登录:

收集所有需要登录的用户的公钥,就是他们自己的id_rsa.pub文件,把所有公钥导入到/home/git/.ssh/authorized_keys文件里,一行一个。

服务器:Ubuntu 14.04 IP:192.168.111.222

4.初始化Git仓库:

先选定一个目录作为Git仓库,假定是/home/my_name/repositorys/git-template.git,在/home/my_name/repositorys目录下输入命令:

sudo git init --bare git-template.git

Git就会创建一个裸仓库,裸仓库没有工作区,因为服务器上的Git仓库纯粹是为了共享,所以不让用户直接登录到服务器上去改工作区,并且服务器上的Git仓库通常都以.git结尾。然后,把owner改为git:

sudo chown -R git:git git-template.git

服务器上:

5.禁用shell登录:

出于安全考虑,第二步创建的git用户不允许登录shell,这可以通过编辑/etc/passwd文件完成。找到类似下面的一行:

git:x:1001:1001:,,,:/home/git:/bin/bash

改为:

git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell

这样,git用户可以正常通过ssh使用git,但无法登录shell,因为我们为git用户指定的git-shell每次一登录就自动退出。

#安装git,如果有权限问题,记得再以下命令前面加上 sudo

6.克隆远程仓库:

现在,可以通过git clone命令克隆远程仓库了,在各自的电脑上运行:

git clone git@XXX.XXX.XXX.XXX:/home/my_name/repositorys/git-template.git
(XXX.XXX.XXX.XXX是服务器的IP)

apt-get install git

7.公钥管理

如果团队很小,把每个人的公钥收集起来放到服务器的/home/git/.ssh/authorized_keys文件里就是可行的。如果团队有几百号人,就没法这么玩了,这时,可以用Gitosis来管理公钥。

#新增用户(用户名为git),用于运行git服务,回车后会提示输入密码

8.使用实例:

  • clone工程:git clone git@192.168.6.80:/home/my_name/repositorys/git-template.git
  • 提交修改:git push ,或指定branchs:git push origin master
  • 更新数据:git pull

adduser git

注:

1.使用”git init –bare”方法创建一个所谓的裸仓库,之所以叫裸仓库是因为这个仓库只保存git历史提交的版本信息,而不允许用户在上面进行各种git操作,如果你硬要操作的话,只会得到下面的错误(”This operation must be run in a work tree”) 这个就是最好把远端仓库初始化成bare仓库的原因。

Git 教程系列文章: 

GitHub 使用教程图文详解  http://www.linuxidc.com/Linux/2014-09/106230.htm 

Git 标签管理详解 http://www.linuxidc.com/Linux/2014-09/106231.htm 

Git 分支管理详解 http://www.linuxidc.com/Linux/2014-09/106232.htm 

Git 远程仓库详解 http://www.linuxidc.com/Linux/2014-09/106233.htm 

Git 本地仓库(Repository)详解 http://www.linuxidc.com/Linux/2014-09/106234.htm 

Git 服务器搭建与客户端安装  http://www.linuxidc.com/Linux/2014-05/101830.htm 

Git 概述 http://www.linuxidc.com/Linux/2014-05/101829.htm 

分享实用的GitHub 使用教程 http://www.linuxidc.com/Linux/2014-04/100556.htm 

Ubuntu下Git服务器的搭建与使用指南  http://www.linuxidc.com/Linux/2015-07/120617.htm

Git 的详细介绍:请点这里
Git 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-05/131057.htm

图片 1

#初始化git仓库,这里我放到/home/git/code目录下面(专门存放代码用)<br>mkdir /home/git/code

cd /home/git/code

git init --bare test.git  #注意:加上--bare参数后,服务端是初始化的[裸仓库]一般服务器上的Git仓库都是以.git结尾的裸仓库

裸仓库没有工作区,因为服务器上的git仓库是为了共享用,不能让用户直接登录到服务器上去修改工作区中的代码,用裸仓库更加安全

现在 服务器 上面的git仓库已经初始化完成,那接下来配置哪些用户可以登录到git服务器,进行git相关操作。

code目录结构:

图片 2

本地:

#以下创建证书登录

#本地生成公钥,位于~/.ssh/id_rsa.pub

ssh-keygen -t rsa ls ~/.ssh/

将用户的公钥(即id_rsa.pub)添加到 服务器上/home/git/.ssh/authorized_keys 文件中,

我这里用scp把本地的公钥(id_rsa.pub)上传到服务器上,然后用命令追加到authorized_keys中

#scp命令 将文件复制到远程服务器上,回车后输入git用户的密码

scp ~/.ssh/id_rsa.pub git@192.168.111.222:/home/git/

#如果ssh端口不是默认的22,则使用以下命令代替上面那条命令(22222为ssh端口号)

scp -P 22222 ~/.ssh/id_rsa.pub git@192.168.111.222:/home/git/ <br>#然后服务器的/home/git/目录下面就多了我们刚才上传的id_rsa.pub

继续回到服务器上:

cd /home/git/

mkdir .ssh

#将本地用户的公钥添加到认证文件中

cat id_rsa.pub >> .ssh/authorized_keys

#修改所有者为git用户

chown -R git:git /home/git

#修改以下目录权限

# 1. 用户home目录755权限

# 2. .ssh目录700权限

# 3. authorized_keys 600权限

本文由太阳集团所有网址16877发布于www.16877.com,转载请注明出处:Ubuntu 14.04下搭建Git服务器

您可能还会对下面的文章感兴趣: