问题引入
最近和一个老同学协作编写代码,所以就到Github上又注册一个Github账号(下面统一称作TechGroup),所以我写的代码就想同时向我自己的Github帐户(下面统一称作MyGithub)和TechGroup提交,这是就会出现一个问题,因为一个ssh key只能用在一个帐户中(当你将一个ssh key添加到两个帐户时,会提示ssh key已经被使用)。
在一台电脑上同时配置两个ssh key
- 首先为TechGroup帐户创建一个ssh key:
$ ssh-keygen -t rsa -C cytmxk@foxmail.com
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/lala/.ssh/id_rsa):~/.ssh/tech_rsa(此处填写rsa文件的路径)
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in yes.
Your public key has been saved in tech_rsa.pub.
The key fingerprint is:
fb:c4:b0:e0:47:fd:be:e0:fb:ea:73:ef:a8:29:d5:22 cytmxk@foxmail.com
The key's randomart image is:
+--[ RSA 2048]----+
| |
| |
| |
| . |
| . S .. |
| . oE=o.. |
| . +o+.. |
| ..+.+.. |
| oOB=+o |
+-----------------+
- 每一台电脑默认只会使用ssh key(~/.ssh/id_rsa)私钥与远程服务端的公钥进行配对,所以现在就是要让电脑知道现在有两个ssh key私钥可以用来配对。
1> 通过ssh-agent来保存两个ssh key私钥
首先通过如下命令列举 ssh-agent中包含的ssh-key私钥:
$ ssh-add -l
The agent has no identities.
可以看到现在ssh-agent中是空的。
如果是在Windows操作环境中,上面的命令会报错:
Could not open a connection to your authentication agent.
解决方法就是执行如下命令进入ssh-add操作环境即可:
$ ssh-agent bash
执行如下命令将两个私钥添加到ssh-agent中:
$ ssh-add ~/.ssh/id_rsa
$ ssh-add ~/.ssh/tech_rsa
$ ssh-add -l
2048 SHA256:U/pK956tFobOPNSFgnny9IKcxXWdFSVMl4wsVQ/izTA /Users/chenyang/.ssh/id_rsa (RSA)
2048 SHA256:uDP8CISrd8Os1vl+wnuPj4ldJaiq2XQnRk9FGKHhDfU /Users/chenyang/.ssh/tech_rsa (RSA)
192:~ chenyang$
可以看到ssh-add -l命令输出中多了一行,这一行就是tech_rsa私钥。
看起来好像一切都很好,但是当你重启电脑后,ssh-agent会被重置为空,
ssh-add 这个命令不是用来永久性的记住你所使用的私钥的。实际上,它的作用只是把你指定的私钥添加到 ssh-agent 所管理的一个 session 当中。而 ssh-agent 是一个用于存储私钥的临时性的 session 服务,也就是说当你重启之后,ssh-agent 服务也就重置了。
因此通过ssh-agent是行不通的,下面来看另一种方法。
2>通过.ssh/config保存两个ssh key私钥
#多个ssh的配置 begin
Host github.com
HostName github.com
IdentityFile ~/.ssh/id_rsa
Host tech.github.com
HostName github.com
IdentityFile ~/.ssh/tech_rsa
#多个ssh的配置 end
可以看到每一个私钥都会对应一个Host。
3> 将创建生成tech_rsa.pub中的内容添加到TechGroup帐户中,添加的流程这里就不赘叙了,接下来测试一下是否添加成功(如果输出如下结果,表明添加成功):
$ ssh -T git@tech.github.com
Hi techgroup01! You've successfully authenticated, but GitHub does not provide shell access.
注意上面的git@tech.github.com中的tech.github.com与config中的tech _rsa的Host保持一致。
接下来就是从远程github资源库下载资源了,
git clone git@github.com:cytmxk/customview.git
此时会使用~/.ssh/id_rsa密钥进行配对
git clone git@tech.github.com:techgroup01/customview.git
此时会使用~/.ssh/tech_rsa密钥进行配对
给一个本地git资源库配置两个远程github资源库
上面只是实现了通过不同的密钥从远程github资源库下载到本地的方法,但是此时会有另一个问题,同一个本地git资源库怎么提交到不同的远程github资源库?那就需要给一个本地git资源库配置两个远程资源库,
执行如下命令即可:
$ git remote add my_origin git@github.com:cytmxk/customview.git
$ git remote add tech_origin git@tech.github.com:techgroup01/customview.git
上面命令中要注意第二句中的远程资源库的Host要和config中相同,可以通过如下命令列举出当前库的所用远程资源库:
$ git remote -v
my_origin git@github.com:cytmxk/customview.git (fetch)
my_origin git@github.com:cytmxk/customview.git (push)
tech_origin git@tech.github.com:techgroup01/customview.git (fetch)
tech_origin git@tech.github.com:techgroup01/customview.git (push)
接下来通过如下命令将本地git资源库提交到不同的远程github资源:
git push my_origin master
git push tech_origin master