【Git】Gitlab、Github、Gitee兼容的开发环境

0x00 git准备

首先确认已安装Git,可以通过 git –version 命令可以查看当前安装的版本。
可以通过命令进行更新

git clone https://github.com/git/git

Git共有三个级别的config文件,分别是systemgloballocal

system 配置整个系统只有一个
global 配置每个账户只有一个
local 在仓库目录才能看到该配置

配置仓库用户信息

  • 一个用户信息走遍各个托管网站

直接把生成的ssh key放到各个网站里,然后配置globalgitconfig,就可以了,不用看下面的方法了。

  • 希望不同托管网站使用不同的用户信息

那么gitlab、github、gitee各需一个不同的密钥。
那就创建三个密钥,不同的网站识别使用对应的密钥。
给不同的仓库配置localgitconfig:

git config --local user.name "你的名字"
git config --local user.email "你的邮箱"

可以继续往下文看。

0x01 生成多个密钥

1. 生成新的 SSH keys

生成多个git密钥

ssh-keygen -t rsa -f ~/.ssh/id_rsa.github -C "xx@xxx.com"
ssh-keygen -t rsa -f ~/.ssh/id_rsa.gitlab -C "xx@xxx.com"
ssh-keygen -t rsa -f ~/.ssh/id_rsa.gitee -C "xx@xxx.com"

在~/.ssh下面会出现三组密钥:

  • id_rsa.github
  • id_rsa.github.pub
  • id_rsa.gitlab
  • id_rsa.gitlab.pub
  • id_rsa.gitee
  • id_rsa.gitee.pub

0x02 添加配置文件

若无 config 文件,则需创建 config 文件

touch ~/.ssh/config

config 里需要填的内容
亲测可以不缩进,所以方便看,建议缩进。

#Default gitHub user Self
Host github
    HostName github.com
    User git
    IdentityFile ~/.ssh/id_rsa.github


Host gitlab
    HostName gitlab.com
    User git
    IdentityFile ~/.ssh/id_rsa.gitlab


Host gitee
    Port 22
    HostName gitee.com
    User git
    IdentityFile ~/.ssh/id_rsa.gitee


# 其他自己搭建的
Host custom
    Port 22
    HostName git.custom.com
    User git
    IdentityFile ~/.ssh/lab_rsa.custom

然后把对应的公钥添加到githubgitlabgitee中。

测试是否成功:

ssh -T git@github
ssh -T git@gitlab
ssh -T git@gitee
ssh -T git@custom

0x03 .ssh/config简单说明

参考https://zhuanlan.zhihu.com/p/35922004

SSH 参数配置有3个层次:

  • 命令行参数,如-p 10086, -i /path/to/identity_file 等选项来设置SSH的端口号或认证证书位置
  • 针对某个用户的配置文件,所在路径为~/.ssh/config,默认是不存在的,需要手动创建
  • 针对系统所有用户的配置文件, 所在路径为/etc/ssh/ssh_config参数重要性的顺序也是1>2>3,即越近的配置重要性越高。

这里主要讲述第2种情况下的配置方式,即针对~/.ssh/config文件的写法进行说明。

主要的规则如下:

  • 每项配置都是参数名 参数值参数值=参数名的形式,其中参数名不区分大小写,而参数值区分大小写
  • 不同主机的配置通过Host参数来区分,一个配置文件里面可以有针对多个Host的配置
  • #开头的是注释
  • 同一个Host的配置内部,参数名 参数值参数值=参数名等价

常见参数类型

Host

类似昵称,用于标识某个特定的配置。
例如:
加如下配置:

Host cluster
	HostName 192.168.11.11
	User tom

想要ssh连接到192.168.11.11主机,拷贝a.txt文件。
先链接服务器:

ssh cluster

然后拷贝,没有配置,要这么写:

scp a.txt tom@192.168.11.11:~/

加了配置,可以简化成这样:

scp a.txt cluster:~/

省略了用户名和IP地址。

HostName

需要ssh连接过去的主机名,一般是IP地址.

User

登录主机的用户名。

IdentityFile

认证证书文件,默认位置是~/.ssh/id_rsa, ~/ssh/id_dsa

Port

SSH访问主机的端口号,默认是22端口,在非默认情况下需要设置该值

其他

常用的参数就这些,别的参数可以在命令行通过man ssh_config来查看。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值