yum 源仓库里的 Git 版本更新不及时,最新版本的 Git 是 1.8.3.1,想要安装最新版本的的 Git,只能下载源码进行安装。
-
依赖库安装
yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel
-
卸载低版本的 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"