centos上安装git服务
1、安装git,直接使用yum安装即可:
yum info git //查看 yum 源仓库的 Git 信息
【官方最新版本已经到了 2.26,想要安装最新版本的的 Git,只能下载源码进行安装。】
yum -y install git
【源码安装】 //依赖库安装 yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel
yum install gcc perl-ExtUtils-MakeMaker
//卸载低版本的 Git
yum remove git
tar -xzvf v2.26.0.tar.gz
cd git-2.26.0
make prefix=/usr/local/git all
make prefix=/usr/local/git install
添加到环境变量 vim /etc/profile
添加这一条: export PATH=”/usr/local/git/bin:$PATH”
source /etc/profile //使配置立即生效 git –version //查看版本号
将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
创建一个git用户组和用户,用来运行git服务: groupadd git useradd git -g git passwd git #参数是用户名 su – git //切换git用户 【注】最好切换到git用户 不然后面新建的git仓库都要改权限
2、创建git用户,git用户可以正常通过ssh使用git,但无法登录shell,因为我们为git用户指定的git-shell每次一登录就自动退出。
useradd -m -d /home/git -s /usr/bin/git-shell git
3、初始化git仓库
mkdir -p /data/git
cd /data/git
git init –bare myproject1.git
chown git.git myproject1.git -R
4、创建免密钥
cd /home/git
mkdir .ssh chmod 700 .ssh touch .ssh/authorized_keys chmod 600 .ssh/authorized_keys chown git.git .ssh -R
5、如果使用Linux可以使用ssh-keygen创建密钥,然后拷贝id_rsa.pub的内容追加的服务器端的git用户下的.ssh/authorized_keys,就可以实现免密码提交,如果是windows可以使用远程连接工具创建密钥。
注意: 【git remote add ssh://git@192.168.1.12:/data/git/myproject1.git】实测时没写ssh:/和ip地址后的 :,花了些时间排查。 git clone git@192.168.1.12:/data/git/project1.git
也可以使用其他用户进行git clone,但是git push的时候会出现权限不足的问题,需要修改对应的权限(vim /etc/passwd) 。
(1)、rsa登录: 收集所有需要登录的用户的公钥,公钥位于id_rsa.pub文件中,把我们的公钥导入到/home/git/.ssh/authorized_keys文件里,一行一个。
如果没有该文件创建它:
$ cd /home/git/
$ mkdir .ssh
$ chmod 700 .ssh
$ touch .ssh/authorized_keys
$ chmod 600 .ssh/authorized_keys
(2)、在Git服务器上首先需要将/etc/ssh/sshd_config中将RSA认证打开,即:
1.RSAAuthentication yes
2.PubkeyAuthentication yes
3.AuthorizedKeysFile .ssh/authorized_keys
修改配置之后,需要重启sshd
systemctl restart sshd.service
可以通过这个命令去测试SSH是否可连接:
ssh -T git@192.168.1.85
然后在服务器,可以通过这个命令查看ssh状态
systemctl status sshd.service
(3)、ssh可以连接了,但git clone的时候,报
fatal: protocol error: bad line length character: 找到/etc/passwd,里面是说:
这样我们的 Git 服务器安装就完成了,接下来我们可以禁用 git 用户通过shell登录,可以通过编辑/etc/passwd文件完成。找到类似下面的一行:
git:x:503:503::/home/git:/bin/bash
改为:
git:x:503:503::/home/git:/sbin/nologin
但就是这个nologin让我们报错了,应该改成:
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell