需求
公司有github账号,自己有github账号
说明
SSH key 可以让你在你的电脑和 Git 服务器之间建立安全的加密连接。一般ssh key存储在 这个目录下/Users/macAcountName/.ssh (macAcountName电脑账户名字不用管一般用item后默认目录就是这个,直接输入.ssh进入即可)
image.png
如果不是默认目录cd一下到上述目录即可
ll //查看目录文件
ps. 这是之前添加的git账户,默认走id_rsa
添加新账户
跟添加一个账户步骤差不多
生成SSHkey
ssh-keygen -t rsa -C "xxx@xx.com"
点击回车后,会出现以下提示
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/macAcountName/.ssh/id_rsa):
如果首次配置一个账号,直接回车,自动取默认路径和名称。
如果是多个git账号配置私钥/公钥,需要自己指定路径和名称,以id_rsa_dq为例,名称可自己定义(直接在冒号后输入id_rsa_dq即可)
继续回车
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
这里取默认值空,最后出现如下图的回显,就说明你配置成功了
Your identification has been saved in /Users/macAcountName/.ssh/id_rsa_dq.
Your public key has been saved in /Users/macAcountName/.ssh/id_rsa_dq.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]-----+
然后再看目录
image.png然后
vim id_rsa_dq.pub
把里面的内容拷贝到剪切板, 或者用命令拷贝(pbcopy < ~/.ssh/id_rsa_dq.pub),粘贴到key中即可
image.png
测试是否链接成功
ssh -T git@github.com //(github.com即你的域名,公司的账号或许就是git.XXX.com)
一般会失败,哈哈,提示:
Permission denied (publickey).
当然成功是:
Welcome to Git@XXX, yourname!
成功就不说了,失败了需要执行
ssh-add ~/.ssh/id_rsa_dq
// 添加成功提示
Identity added: /Users/macAcountName/.ssh/id_rsa_dq (/Users/macAcountName/.ssh/id_rsa_dq)
// 再执行 ssh -T git@github.com 应该就是成功了
至此,还没有完。。。如果你在github等上面有两个账号,可能就会导致git提交失败,那么这里就需要配置~/.ssh/config这个文件( 没有config文件的自己建 )
touch config // 建config
image.png
#thub user(first@email.com)
Host github1
HostName git.some.com
User git
IdentityFile ~/.ssh/id_rsa
#dq
Host dq (名称自定义)
HostName github.com (服务器地址)
User git
IdentityFile ~/.ssh/id_rsa_dq (密钥存储路径)
规则:从上至下读取config的内容,在每个Host下寻找对应的私钥。这里将GitHub SSH仓库地址中的git@github.com替换成新建的Host别名如:dq,那么原地址是:git@github.com:username/Mywork.git,替换后应该是:dq:username/Mywork.git
使用
以前一个账户的时候:
$ git clone git@github.com: 用户名/XXX.git
现在:
$ git clone git@github1: 用户名1/XXX.git // 其实就是在github上clone代码的地址把@符号后面 冒号:前面的(github.com) 替换成之前在config里面定义的HOST别名,如上,第一个是github1
第二个账户就是:
$ git clone git@dq: 用户名2/XXX.git
最后,在clone完的项目仓库目录里最好定义一下局部账户名跟邮箱,这样提交的时候显示的账户名邮箱就是各自对应的~ 不然就显示全局定义的~ 想看提交的账户git log 就能看
$ git config user.name "one_name" ; git config user.email "one_email"
$ git config user.name "two_name" ; git config user.email "two_email"
QA (这部分我没有遇到,出处:http://www.jianshu.com/p/fbbf6efb50ba 这篇也写的不错,大家可以参考)
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: 报错如下:
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
网友评论