frankliuch

导航

git服务器搭建

yum 源仓库里的 Git 版本更新不及时,最新版本的 Git 是 1.8.3.1,想要安装最新版本的的 Git,只能下载源码进行安装。

 

  • 依赖库安装

 yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel

 yum install gcc perl-ExtUtils-MakeMaker
  • 卸载低版本的 Git

通过命令:git –-version 查看系统带的版本

yum remove git

  • 下载新版的 Git 源码包(我放的了  /usr/local/git 的目录下了,git是我自己mkdir的目录)

进入:/usr/local下,新建git目录:  

mkdir git 

cd git 

在线下载最新的源码包

wget https://github.com/git/git/archive/v2.9.2.tar.gz

解压到当前目录 tar -xzvf v2.9.2.tar.gz

  • 安装 Git

 cd git-2.9.2

make prefix=/usr/local/git all

 make prefix=/usr/local/git install

  • 添加到环境变量

 vi /etc/profile  

添加这一条:   export PATH="/usr/local/git/bin:$PATH" 

source /etc/profile   #是配置立即生效

  • 将git设置为默认路径,不然后面克隆时会报错

ln -s /usr/local/git/bin/git-upload-pack /usr/bin/git-upload-pack 

ln -s /usr/local/git/bin/git-receive-pack /usr/bin/git-receive-pack 

报错如下:

bash: git-upload-pack: command not found
fatal: The remote end hung up unexpectedly

第二步,创建一个git用户组和用户,用来运行git服务:

groupadd git

useradd git -g git

passwd git #参数是用户名

最好切换到git用户 不然后面新建的git仓库都要改权限 烦烦烦!!

su - git

第三步,

创建证书登录:

在Git服务器上首先需要将/etc/ssh/sshd_config中将RSA认证打开,

即:

1.RSAAuthentication yes

2.PubkeyAuthentication yes

3.AuthorizedKeysFile .ssh/authorized_keys

这里我们可以看到公钥存放在/home/git/.ssh/authorized_keys文件中。

所以我们在/home/git下创建.ssh目录,然后创建authorized_keys文件,并将刚生成的公钥导入进去。

然后再次clone的时候,或者是之后push的时候,就不需要再输入密码了:

 

$ cd /home/git/
$ mkdir .ssh #新建文件夹
$ chmod 700 .ssh 
$ touch .ssh/authorized_keys  #新建文件
$ chmod 600 .ssh/authorized_keys

第四步,初始化Git仓库

$ cd /home/git

$ git init --bare test1.git

Initialized empty Git repository in /home/git/test1.git/

以上命令会创建一个空仓库,服务器上的Git仓库通常都以.git结尾。

把仓库所属用户改为git

chown -R git:git  /home/git/test1.git/

第五步、本地克隆仓库

git clone git@10.6.0.241:/home/gitrepo/test1.git

Cloning into 'test1'... warning: You appear to have cloned an empty repository. Checking connectivity... done.

禁止Shell登录

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

git:x:502:502::/home/git:/bin/bash
改为

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

 

使用以下命令生成SSH Key:

ssh-keygen -t rsa -C "youremail@example.com"

posted on 2018-03-05 10:57  frankliuch  阅读(185)  评论(0编辑  收藏  举报