今天分享一个 git 的配置,可以在同一 ip 地址下同时配置 github 和 gitlab 的 SSH,从而实现两个远程仓库的自动识别并免密push和clone。
1. 清除 git 的全局设置(针对已安装 git)
新安装 git 跳过。
若之前对 git 设置过全局的 user.name
和 user.email
。 类似 (用 git config --global --list
进行查看你是否设置)
必须删除该设置
$ git config --global --unset user.name "你的名字"
$ git config --global --unset user.email "你的邮箱"
2. 生成新的 SSH keys
1)GitHub 的钥匙
指定文件路径,方便后面操作:~/.ssh/id_rsa.github
ssh-keygen -t rsa -f ~/.ssh/id_rsa.github -C "lx@qq.com"
直接回车3下,什么也不要输入,就是默认没有密码。
注意 github 和 gitlab 的文件名是不同的。
2)GitLab 的钥匙
ssh-keygen -t rsa -f ~/.ssh/id_rsa.gitlab -C "lx@vip.qq.com"
3)完成后会在~/.ssh / 目录下生成以下文件
-
id_rsa.github
-
id_rsa.github.pub
-
id_rsa.gitlab
-
id_rsa.gitlab.pub
3. 添加识别 SSH keys 新的私钥
默认只读取 id_rsa,为了让 SSH 识别新的私钥,需要将新的私钥加入到 SSH agent 中
$ ssh-agent bash
$ ssh-add ~/.ssh/id_rsa.github
$ ssh-add ~/.ssh/id_rsa.gitlab
4. 多账号必须配置 config 文件(重点)
若无 config 文件,则需创建 config 文件
创建config文件
$ touch ~/.ssh/config
config 里需要填的内容
Host github.com // 不动, github 网址
HostName github.com // 不动
User xxx@xxx.com // 你自己的github邮箱
PreferredAuthentications publickey // 不动
IdentityFile ~/.ssh/id_rsa.github // 不动
Port 443 // 有的时候不一定需要
// 如果ssh -T git@github.com的时候报 ssh: connect to host github.com port 22: Operation timed out就把Port这条加上吧
Host 192.168.0.231 // 你们公司gitlab的ip地址/网址
HostName 192.168.0.231 //与Host保持一致,这里实际上是真实的连接地址
User xxx@xxx.com // 你gitlab的邮箱
IdentityFile ~/.ssh/id_rsa.gitlab // 不动
Port 64222 // 你们公司gitlab的ip端口,有的时候不一定需要
下面对上述配置文件中使用到的配置字段信息进行简单解释:
-
Host 它涵盖了下面一个段的配置,我们可以通过他来替代将要连接的服务器地址。 这里可以使用任意字段或通配符。 当ssh的时候如果服务器地址能匹配上这里Host指定的值,则Host下面指定的HostName将被作为最终的服务器地址使用,并且将使用该Host字段下面配置的所有自定义配置来覆盖默认的/etc/ssh/ssh_config配置信息。
-
Port 自定义的端口。默认为22,可不配置
-
User 自定义的用户名,默认为git,可不配置
-
HostName 真正连接的服务器地址
-
PreferredAuthentications 指定优先使用哪种方式验证,支持密码和秘钥验证方式
-
IdentityFile 指定本次连接使用的密钥文件
5.在 github 和 gitlab 网站添加 ssh
可以用 cat 命令把 公钥 的内容打出来复制到 github 和 gitlab 的 SSHKEY上
$ cat ~/.ssh/id_rsa.github.pub
$ cat ~/.ssh/id_rsa.gitlab.pub
Github
直达地址:Sign in to GitHub · GitHub
过程如下:
-
登录 Github
-
点击右上方的头像,点击
settings
-
选择
SSH key
-
点击
Add SSH key
在出现的界面中填写 SSH key 的名称,填一个你自己喜欢的名称即可。 将上面拷贝的~/.ssh/id_rsa.xxx.pub
文件内容粘帖到 key 一栏,在点击 “add key” 按钮就可以了。
添加过程 github 会提示你输入一次你的 github 密码 ,确认后即添加完毕。
Gitlab
直达地址:https://gitlab.com/profile/keys
-
登录 Gitlab
-
点击右上方的头像,点击
settings
-
后续步骤如 Github
6.测试是否连接成功
由于每个托管商的仓库都有唯一的后缀,比如 Github 的是 git@github.com:*。
所以可以这样测试:
ssh -T git@github.com
Git lab 的可以这样测试:
ssh -T git@gitlab.com
根据自己的 config 文件配置来。
结果如果出现这个就代表成功:
-
GitHub -> successfully
-
GitLab -> Welcome to GitLab
测试 clone 项目
git clone git@github.com:facebookresearch/segment-anything.git
这样之后,以后自己的项目仓库就可以免密 clone 和 push 了。
7.过程中出现的问题
Clone 下来公司 gitlab 之后,再 push 的时候提示
*** Please tell me who you are.
Run
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
to set your account's default identity.
Omit --global to set the identity only in this repository
那就设置一下全局的 name 和 email 为公司 gitlab 账户即可,目前实测不会影响 github 的连接
git config --global user.email "xxx@xxx.com"
git config --global user.name "xxx"
好像还可以配置 local,而不用配置 global
参考: