在公司上班項目是push到公司自己搭的gitlab箱叁,平時自己的項目是push到github。他們分別使用的是不同的賬號氨肌。然后這樣就導致有不同的ssh-key莺治,
在工作的這段時間廓鞠,一直都是使用gitlab的賬號,也是在做公司的項目谣旁,所以本地的ssh-key也是gitlab的床佳。然后最近開始在github上寫插件,原本我是認為只要將本地這個ss-key添加到github上面(ps:本地的ssh-key的email不是用github的email生成的榄审,以為這是兩個不同的賬號)砌们,然后就可以push代碼到github上,然而瘟判,并不可以怨绣。然后就開始一頓瞎搞角溃。
查看全局配置的name和email命令:
git config --global --list
查看全局配置
git config -l
配置全局的name和email:
git config --global user.name "issac"
git config --global user.email "issaxite@gmail.com"
刪除全局配置的name和email:
git config --global --unset user.name
git config --global --unset user.email
查看當前項目的配置:
git config --local --list
配置當前項目的name和email(非全局拷获,全局的配置比當前項目的優(yōu)先級要
![Uploading Paste_Image_669933.png . . .]
高):
git config user.name "issac"
$ git config user.email "issaxite@gmail.com"
生成新的ssh-key,使用:
ssh-keygen -t rsa -C "issaxite@email.com"
命令默認生成的話减细,會覆蓋原有的ssh-key匆瓜,因此為了共存,所以需要給新的ssh-key指定別名,有兩種方法可以指定別名生成ssh-key:
1:
2.ssh-keygen -t rsa -C "issaxite@your.com” -f ~/.ssh/github-rsa //直接一條命令指定轮锥。
以上的兩條命令都會生成一個公鑰(xxx.pub)和一個私鑰
生成完之后淑翼,需要添加私鑰:
ssh-add ~/.ssh/id_rsa_issaxite
如果執(zhí)行ssh-add時提示"Could not open a connection to your authentication agent"身笤,可以現(xiàn)執(zhí)行命令(我是沒有出現(xiàn)這個問題):
可以通過 ssh-add -l 來確私鑰列表
$ ssh-add -l
可以通過 ssh-add -D 來清空私鑰列表
$ ssh-add -D
或者
ssh-agent bash
ssh-add ~/.ssh/id_rsa_issaxite
然后為了可以識別根據(jù)不同的服務識別不同的ssh-key,需要在.ssh文件夾下新建個config文件桐筏,個人認為這個config的相當于一個映射文件,看看配置的內(nèi)容就明白:
gitlab
Host git.hingyin.com //這個和你的clone的ssh的域名相關
HostName git.hingyin.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa
github
Host github.com
HostName github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_issaxite
然后是將公鑰添加到不同的git服務器拇砰,接著就可以測試一下梅忌,有沒有成功配置:
ssh -T git@github.com
參考鏈接:
http://jingyan.baidu.com/article/948f592414ad67d80ef5f966.html
http://www.cnblogs.com/zichi/p/4704824.html
https://my.oschina.net/stefanzhlg/blog/529403
使用ssh-key的原因:
https://gold.xitu.io/post/58a8f3295c497d005fbd58b1
插曲:
一個公鑰如果被一個github賬號在使用,那么另外一個github賬號就不能使用除破。