http://suqianghotel.com/2016/09/13/mac-mulit-git-account-config/
概述
代码管理工具从流行的CVS,到SVN,到如今的Git, 尤其是Github的存在,加之git在代码管理的种种优势,git已经被越来越多的程序员喜爱。在日常开发中,我们可能面临着这样的尴尬:公司本身有git服务器,管理自己的代码。爱折腾的程序员,可在各大第三方代码管理平台,
github
,coding.net
,码云
,也有着自己的账号,对于github,可能也有两个账号;这是就需要配置多个SSH, 为了方便在一台电脑上对多个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,所以会比较多,这里不必在意,现在我就码云
为例,说明详细配置
- 生成 SSH key
1
|
ssh-keygen -t rsa -C "xxx@xx.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]-----+ |
- 将生成的公钥拷贝到剪贴板上,到git管理页面贴入即可
1
|
pbcopy < ~/.ssh/id_rsa_oschina.pub
|
其中id_rsa_oschina
.pub, 就是你刚才输入的名称
oschina配置:
- 测试连接是否成功
1
|
ssh -T git@git.oschina.net
|
若返回
1
|
Welcome to Git@OSC, yourname!
|
则证明添加成功。
若返回
1 2 3 4 5 |
The authenticity of host 'git.oschina.net (116.211.167.152)' can't be established. ECDSA key fingerprint is SHA256:FQGC9Kn/eye1W8icdBgrQp+KkGYoFgbVr17bmjey0Wc. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added 'git.oschina.net,116.211.167.152' (ECDSA) to the list of known hosts. Permission denied (publickey). |
则未成功,执行
1
|
ssh-add ~/.ssh/id_rsa_oschina
|
如果ssh-add 不成功,可以直接进入第5步
如果成功再次重复执行第四步
- 至此是否已经配置完成,答案
否
如果你在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 (密钥存储路径) |
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