git多个账号配置

操作步骤

如果我们Mac上面已经有了ssh-key再创建ssh-key的话,需要给我们的ssh-key文件取不同的名字,默认是id_rsa,如果不重新起名的话,会把原有的给覆盖掉。

1.新建ssh-key&重新命名

1
2
3
4
5
6
//切换到ssh目录
cd ~/.ssh
//新建ssh-key
ssh-keygen -t rsa -C "mywork@email.com"
//为新建的ssh-key重新命名
Enter file in which to save the key (/Users/bombvote-zql/.ssh/id_rsa):id_ras_bill_github

2.新ssh-key添加到ssh agent中

因为默认只读取id_rsa,为了让SSH识别新的私钥,需将其添加到SSH agent中:

3.配置 将不同账号的工程图服务器与ssh-key关联

1
2
3
4
5
6
7
8
9
10
11
12
#thub user(first@email.com)
Host github1
HostName git.some.com/
User git
IdentityFile /Users/bombvote-zql/.ssh/id_rsa

# second user(second@email.com)
# 建一个github别名,新建的帐号使用这个别名做克隆和更新
Host github2
HostName github.com
User git
IdentityFile /Users/bombvote-zql/.ssh/id_ras_bill_github

4.在git服务器上添加公钥

1
2
vim ~/.ssh/id_rsa_bill_github.pub
然后将内容复制添加到服务器账号里面
1
2
测试一下:ssh -T github2
Hi 0xJoker! You've successfully authenticated, but GitHub does not provide shell

其规则就是:从上至下读取config的内容,在每个Host下寻找对应的私钥。这里将GitHub SSH仓库地址中的git@github.com替换成新建的Host别名如:github2,那么原地址是:git@github.com:username/Mywork.git,替换后应该是:github2:username/Mywork.git.


下面是详细步骤

SSH key 可以让你在你的电脑和 Git 服务器之间建立安全的加密连接。一般你的ssh key存储在 这个目录下/Users/{username}/.ssh

1
cd /Users/{accountname}/.ssh

查看.ssh目录会有这样几个文件

1
2
3
4
5
6
7
8
-rw-r--r--@ 1 {username}  staff   280B  8 30 15:12 config    
-rw------- 1 {username} staff 3.2K 8 29 17:42 id_rsa
-rw-r--r-- 1 {username} staff 748B 8 29 17:42 id_rsa.pub
-rw------- 1 {username} staff 3.2K 8 29 14:31 id_rsa_github
-rw-r--r-- 1 {username} staff 748B 8 29 14:31 id_rsa_github.pub
-rw------- 1 {username} staff 1.6K 8 30 15:32 id_rsa_gitlab
-rw-r--r-- 1 {username} staff 397B 8 30 15:32 id_rsa_gitlab.pub
-rw-r--r--@ 1 {username} staff 1.5K 9 2 10:06 known_hosts

如果你的目录下,没有你的目录下没有这些文件,没关系,下面将详细讲解这些文件的作用,以及如何生成
由于笔者已经配置过自己github和公司gitlab,所以会比较多,这里不必在意,现在我就码云为例,说明详细配置

1. 生成 SSH key

1
ssh-keygen -t rsa -C "developer.bogle@qq.com"

输入上述命令,点击回车后,会出现以下提示

1
2
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/{username}/.ssh/id_rsa):

这里是提示你生成的ssh key 的存储路径和名称;如果你是简单的配置一个账号,直接回车,自动取默认路径和名称。如何你是为多个git账号配置私钥/公钥,你需要自己指定路径和名称,笔者用的是id_rsa_oschina,名称可自己定义,具体如下:

1
2
Generating public/private rsa key pair.  
Enter file in which to save the key (/Users/{username}/.ssh/id_rsa): /Users/{username}/.ssh/id_rsa_oschina

继续回车

1
2
Enter passphrase (empty for no passphrase):
Enter same passphrase again:

这里取默认值空,回车即可,最后出现如下图的回显,就说明你配置成功了

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Your identification has been saved in /Users/{username}/.ssh/id_rsa_oschina.
Your public key has been saved in /Users/{username}/.ssh/id_rsa_oschina.pub.
The key fingerprint is:
SHA256:lEmncZqtuXuHgZ4XtkVMkazLaTC5XgN0VLjYi3T8Fk8 xxx@xxx.com
The key s randomart image is:
+---[RSA 2048]----+
| o o..=+o |
| . @. + o X|
| B..B o |
| . oB B . E|
| So X = + |
| ..* X o .|
| ..+ O o |
| o.* . |
| .o . |
+----[SHA256]-----+

将生成的公钥(id_rsa_oschina.pub为公钥文件,id_rsa_oschina为私钥文件)拷贝到剪贴板上,到git管理页面贴入即可

1
pbcopy < ~/.ssh/id_rsa_oschina.pub

2. oschina配置

2.1 测试连接是否成功

1
ssh -T git@git.oschina.net

未成功,执行

1
2
3
ssh-add ~/.ssh/id_rsa_oschina

Hi oschina! You've successfully authenticated, but GitHub does not provide shell

如果ssh-add 不成功,可以直接进入下一步
如果成功再次重复执行这一步

3. 多账号配置

如果你在github等上面有两个账号,可能就会导致git提交失败,那么这里就需要配置~/.ssh/config这个文件

打开config文件

1
open ~/.ssh/config

在文件中添加如下

1
2
3
4
5
#oschina
Host oschina (名称自定义)
HostName git.oschina.net (服务器地址)
user git (`git`@git.oschina.net 与 这里`git`名称是一致的,也可自定义,但不建议修改)
IdentityFile ~/.ssh/id_rsa_oschina (密钥存储路径)

clone 地址:

1
https://bogle-zhao(Host 自定义名称)@github.com/bogle-zhao/spring-framework.git

4. QA

Q: 按照上述步骤执行了,仍然Permission denied (publickey)

试如下方案:

  • 清空~/.ssh/known_hosts文件
  • 执行ssh-add -D(删除所有), 再次执行ssh-add -A(添加所有)

Q: 此次配置成功后,待下次重新启动电脑后,git提交又提示Permission denied (publickey)

  • 每次重新执行ssh-add -A
  • 每次重新执行嫌麻烦 ,ssh-add -A -K,添加到钥匙串内,这样下次如果没有知道密钥,那么则会自动取钥匙中存取的密钥

Q: 报错如下:

1
2
remote: Permission to username1/xxxx.git denied to username2.
fatal: unable to access 'https://github.com/username1/xxxx.git/': The requested URL returned error: 403
  • 原因可能是你有两个github账户, 以前使用一个登陆并管理代码,切换另一个账号管理代码时, 钥匙串存储仍然是第一个用户的密码
  • 执行git credential-osxkeychain erase

5. 参考

GitHub Help