git搭建远程服务器,手把手教你如何搭建一个Git远程仓库

搭建Git服务器需要准备一台运行Linux的机器,我这里使用一个centos的Docker容器作为示例,话不多说,上步骤;

Docker虚拟机准备

使用现成服务器的同学跳过此步骤

下载最新的centos镜像(现在最新版本是8.3)并运行,命令如下:

docker pull centos

docker run --name gitserver -itd --privileged=true -p 8000:22 centos /sbin/init

docker exec -it gitserver /bin/bash

注意,这边我将本机的8000端口映射到服务器的22端口,作为后续的远程仓库访问端口

安装Git

(如果因为系统权限的问题无法执行安装命令, 可在命令前添加sudo提权)

yum install -y git

yum install -y passwd

yum install -y cracklib-dicts

// 容器默认都没有安装sshd服务, 使用非容器的同学注意区别;

yum install -y openssh-server

添加git用户

为了服务器访问安全及Git服务的远程访问需要, 系统上需要创建一个git用户

adduser git

更改密码

passwd git

连续两次输入密码后按回车

启动ssh服务

对于使用非容器服务器的同学,已经启用sshd服务的不在执行此步骤

生成sshd所需的秘钥文件并后台启动sshd服务,操作命令:

ssh-keygen -t dsa -f /etc/ssh/ssh_host_ecdsa_key

ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key

ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key

/usr/sbin/sshd -D &

切换为git用户

su - git

注意'-'两边都有空格

为什么这边切换为git用户? 因为后续几个步骤需要有创建文件夹/文件的动作, 如果使用root用户将可能导致git用户无权访问(也可免去root用户操作后更换文件权限的步骤);

添加git的远程公钥

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

mkdir .ssh

echo "********公钥文件中的所有内容********">~/.ssh/authorized_keys

Windows电脑公钥文件路径一般是C:\Users\Administrator\.ssh目录下

Linuex电脑则在~/.ssh路径下

如果你本机没有找到id_rsa.pub文件则可以使用命令生成一个

ssh-keygen -o

首先 ssh-keygen 会确认密钥的存储位置(默认是 .ssh/id_rsa),然后它会要求你输入两次密钥口令。 如果你不想在使用密钥时输入口令,将其留空即可。

Windows电脑需要先安装git软件并运行Git Bash后执行此命令。

创建git裸仓库

git init --bare example.git

克隆远程仓库到本地

因为我容器暴露的端口是8000,所以连接如下:

克隆成功

Cloning into 'example'...

warning: You appear to have cloned an empty repository.

服务器正在使用基于公钥的 SSH 验证模式,克隆过程中不会提示需要输入密码。

如果有提示输入密码,则意味着在[添加git的远程公钥]这个步骤中没有操作成功。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值