Centos搭建Git服务端

本文详细介绍了如何从零开始搭建一个Git服务器,包括安装Git、创建Git用户、初始化仓库、配置SSH公钥验证等步骤,实现无需密码即可进行仓库操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先需要安装git,可以使用yum源在线安装

yum install -y git

创建一个git用户,用来运行管理git服务

adduser git

初始化git仓库(这里我们选择/home/git/123.git来作为我们的git仓库)

记得先切换为git用户(su git),在/home/git目录下执行

git init --bare 123.git

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

到这里,Git服务器就已经搭得差不多了,下面我们在客户端clone一下远程仓库

git clone ssh://git@121.40.17.218:/home/git/123.git

需要服务端git用户的密码,但已经可以用了。

-----------------------利用SSH的公钥来完成验证(免密码)----------------------

创建SSH Key

首先在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:

$ ssh-keygen -t rsa -C "xulan@yunhetong.net"

可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。

Git服务端打开RSA认证

Git服务器上添加你的公钥用来验证你的信息,在Git服务器上首先需要将/etc/ssh/sshd_config中将RSA认证打开,即:

1.RSAAuthentication yes    

2.PubkeyAuthentication yes    

3.AuthorizedKeysFile  .ssh/authorized_keys

这里我们可以看到公钥存放在.ssh/authorized_keys文件中。所以我们在git服务器的/home/git下创建.ssh目录,然后创建authorized_keys文件,并将客户端刚生成的公钥id_rsa.pub导入进去(这里创建.ssh文件夹和authorized_keys文件一定要用git用户)。

然后再clone,发现还是要密码。。。

相关权限设置

SSH 服务证书验证方式登录,对相关目录和文件的权限有要求。权限配置异常可能会导致登录失败。

  • .ssh 目录的权限配置

  使用如下指令,确保 $HOME/.ssh 目录只有所有者才有权写入:

  chmod 700 ~/.ssh
  • authorized_keys 文件的权限配置

  使用如下指令,确保其它用户对 authorized_keys 文件没有修改权限

  chmod 600 ~/.ssh/authorized_keys

以上两个权限设置语句一定要用git用户执行

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

禁用git用户的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每次一登录就自动退出。

转载于:https://www.cnblogs.com/xulan0922/p/9219129.html

### 三级标题:安装 Git 在 Linux 系统上搭建 Git 服务端的第一步是安装 Git。可以通过包管理器(如 `yum` 或 `apt`)安装 Git。以基于 `yum` 的系统(如 CentOS 或 RHEL)为例: ```bash # 安装 Git sudo yum install -y git # 查看 Git 版本以确认安装是否成功 git --version ``` 如果系统需要多个用户管理 Git 服务,则可以创建一个专用的 `git` 用户[^4]。 ### 三级标题:创建 Git 用户 创建一个专用的 `git` 用户可以增强系统的安全性,确保 Git 服务由独立的用户管理: ```bash # 添加 git 用户 sudo useradd git # 给 git 用户设置密码 sudo passwd git ``` 完成设置后,切换到 `git` 用户并继续后续操作: ```bash # 切换到 git 用户 su - git ``` ### 三级标题:初始化 Git 仓库 在服务器上创建一个目录用于存放 Git 仓库,并初始化一个裸仓库(bare repository),这是 Git 服务器的标准做法: ```bash # 创建仓库目录 mkdir -p /home/git/repositories # 进入仓库目录 cd /home/git/repositories # 初始化裸仓库 git init --bare example.git ``` ### 三级标题:配置 SSH 访问 为了确保客户端可以通过 SSH 协议访问 Git 仓库,需要配置 SSH 公钥认证: 1. 在客户端生成 SSH 密钥对(如果尚未生成): ```bash ssh-keygen -t rsa -b 4096 ``` 2. 将客户端的公钥文件(通常是 `~/.ssh/id_rsa.pub`)内容添加到服务器端的 `~/.ssh/authorized_keys` 文件中。 3. 确保 `.ssh` 目录和 `authorized_keys` 文件的权限正确: ```bash chmod 700 ~/.ssh chmod 600 ~/.ssh/authorized_keys ``` ### 三级标题:限制 Git 用户的 Shell 访问 为了进一步增强安全性,可以限制 `git` 用户仅能使用 Git 命令,而不能登录系统 shell。这可以通过修改 `/etc/passwd` 文件实现: ```bash # 修改 git 用户的 shell sudo usermod -s /usr/bin/git-shell git ``` 确保 `/etc/passwd` 文件中 `git` 用户的行如下所示: ``` git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell ``` ### 三级标题:客户端克隆仓库 客户端可以通过 SSH 协议克隆远程仓库: ```bash # 克隆远程仓库 git clone git@your_server_ip:/home/git/repositories/example.git ``` ### 三级标题:相关问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值