centos7下git的安装和配置

网友投稿 1408 2022-10-08

centos7下git的安装和配置

centos7下git的安装和配置

git的安装:

yum 源仓库里的 Git 版本更新不及时,最新版本的 Git 是 1.8.3.1,但是官方最新版本已经到了 2.9.2。想要安装最新版本的的 Git,只能-源码进行安装。

1. 查看 yum 源仓库的 Git 信息:

1

# yum info git

​​​​

可以看出,截至目前,yum 源仓库中最新的 Git 版本才 1.8.3.1,而查看最​​新的 Git 发布版本​​,已经 2.9.2 了。

2. 依赖库安装

1

2

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

# yum install gcc perl-ExtUtils-MakeMaker

3. 卸载低版本的 Git

通过命令:​​git –-version​​​ 查看系统带的版本,Git 版本是: ​​1.8.3.1​​,所以先要卸载低版本的 Git,命令:

1

# yum remove git

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

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

# cd git

在线-最新的源码包

1

# wget CentOS 系统中指定的目录下。

5. 解压当前目录

1

# tar -xzvf v2.9.2.tar.gz

6. 安装 Git

分别执行以下命令进行编译安装,编译过程可能比较漫长,请耐心等待完成。

1

2

3

# cd git-2.9.2

# make prefix=/usr/local/git all

# make prefix=/usr/local/git install

7. 添加到环境变量

vim /etc/profile

#如果没有vim,则安装vim工具   yum install vim

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

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

8. 查看版本号

1

2

# git --version

git version 2.9.2

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

[root@localhost code]$ ln -s /usr/local/git/bin/git-upload-pack /usr/bin/git-upload-pack

[root@localhost code]$ ln -s /usr/local/git/bin/git-receive-pack /usr/bin/git-receive-pack

至此,CentOS 就安装上了最新版本的 Git。

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

$ groupadd git$ useradd git -g git$ passwd git #参数是用户名

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

$ su - git

第三步,创建证书登录:

如何生成密钥:​​javascript:void(0)​​

备注:下边虚线内容为多余内容,只是留着存档而已。于本教程没有关系

添加证书之前,还要做这么一步:

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

即:

1.RSAAuthentication yes

2.PubkeyAuthentication yes

3.AuthorizedKeysFile .ssh/authorized_keys

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

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

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

Zhu@XXX/E/testgit/8.34 $ git clone git@192.168.8.34:/data/git/learngit.git Cloning into 'learngit'... warning: You appear to have cloned an empty repository. Checking connectivity... done.

===============================

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

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

第四步,初始化Git仓库

$ cd /home/git$ git init --bare test.gitInitialized empty Git repository in /home/git/test.git/

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

特别注意,如果后期在增加新的仓库是,因为无法连接git用户了,所以有两种方式进行添加仓库

1:把配置文件改回来,进入git用户,增加仓库2:用root用户创建仓库,让后进行更改文件所属owner  $chown -R git:git test.git

第五步、本地克隆仓库

$ git clone git@your-ip:test.gitCloning into 'test'...warning: You appear to have cloned an empty repository.Checking connectivity... done.

your-ip 为您 Git 所在服务器 ip

用git clone 获取服务器上的代码

[root@localhost code]$ git clone root@192.168.57.61:/root/code.git

报错如下:

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

什么原因呢?原来代码服务器【192.168.57.61】上的git安装路径是/usr/local/git,不是默认路径,根据提示,在git服务器192.168.57.61上, 建立链接文件:

[root@localhost code]# ln -s /usr/local/git/bin/git-upload-pack /usr/bin/git-upload-pack

再次,执行git clone ,果真可以了。

当然,如果无法修改git代码服务器上配置,可以在clone时,添加--upload-pack选项来指定git服务器上的git-upload-pack 路径,达到上面相同的目的,如下所示:

[root@localhost code]$ git clone --upload-pack "/usr/local/git/bin/git-upload-pack" root@192.168.57.61:/root/code.git

当然,也许你会遇到git-receive-pack 之类的错误,很有可能和这个原理是一样的,请采用类似的操作即可

5.禁止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每次一登录就自动退出

参考文档:

git/ssh捋不清的几个问题   服务器搭建   https://zybuluo.com/zhutoulwz/note/30495

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序商城,微信小程序demo(好用的微信商城小程序)
下一篇:关于Kafka消费者订阅方式
相关文章

 发表评论

暂时没有评论,来抢沙发吧~