Git拾遺:一機(jī)多SSH-Key管理

一句話概括本文

在需要用到多個ssh-key的場景,通過配置config文件解決此問題。


引言

關(guān)于Git的使用總結(jié)以前已經(jīng)寫過一篇文章了:小豬的Git使用總結(jié)
應(yīng)付日常開發(fā)基本夠用了,但在實際開發(fā)中,會遇到各種各樣的問題。
比如我司最近把項目都從自己的Gitlab服務(wù)器上遷移到碼云上,就遇到
了一個問題:多個SSH-key管理的問題。一般來講呢,一個ssh-key是
可以用在多個Git服務(wù)器的,這東西只是用于加密訪問,只要服務(wù)器上的
公鑰能夠和本地的私鑰配對就可以了。但是呢,不同的賬號不能用一樣的
公鑰

如果你用過Git提交代碼,相信你對SSH Key不會陌生,在Clone項目的
時候可以看到有兩種可選協(xié)議 HTTPS和SSH

鏈接是這樣的:

https://gitee.com/xxx/YYY.git
git@gitee.com:xxx/YYY.git

走Https協(xié)議,可以clone任何項目,但是Push時需要輸入賬號密碼
走ssh協(xié)議,必須是項目的擁有者和管理員才能clone,配置了ssh-key的話,推送的
時候,不用輸入賬號密碼(前提是你在配置ssh-key的時候沒有設(shè)置密碼),直接就能提交。

可以通過下面簡單的命令創(chuàng)建一個ssh-key

cd ~/.ssh

# 如果路徑不存在的話,鍵入下述命令創(chuàng)建ssh文件夾
mkdir ~/.ssh

# 鍵入下述命令生成ssh-key的公鑰和私鑰
# 會讓你依次輸入文件名,密碼,密碼,結(jié)束后默認(rèn)生成id_rsa和id_rsa.pub
ssh-keygen -t rsa -C "xxx@xxx.cn"

# 你還可以寫得簡短點直接把名字寫在命令后
ssh-keygen -t rsa -C "xxx@xxx.cn" -f ~/.ssh/id_rsa_xx

# 上面這個命令就會生成id_rsa_xx和id_rsa_xx.pub的私鑰和公鑰了。

ssh-key創(chuàng)建完后,需要打開公鑰,復(fù)制里面的內(nèi)容,然后貼到你Gitlab,Github,
碼云的SSH-Key配置頁,比如我的:

配置成功后,命令行鍵入:

ssh -T git@gitee.com

如果出現(xiàn)這樣的提示,說明配置完成~


問題來了

一般來講,除了公司倉庫外,開發(fā)者一般也會有自己的Git倉庫,比如我有自己的
Github碼云coding.net,如果是一樣的郵箱,那還好,
可以git remote add 命令添加分支別名,比如:

git remote add origin xxx@xxx.git
git remote add osc yyy@yyy.git

然后push或者pull的時候手動指定遠(yuǎn)程倉庫對應(yīng)的分支即可

git push origin master
git pull osc master

但是問題來了,公司郵箱和自己郵箱不一樣,如果你直接執(zhí)行
上面那個ssh-keygen -t rsa -C "xxx@xxx.cn"創(chuàng)建是會覆蓋掉原先的ssh-key,
然后出現(xiàn)公司項目能Push,自己項目不能Push的問題。

解決方法如下

  • Step 1:假設(shè)我有一個自己的賬號和公司賬號,通過下述命令可以創(chuàng)建兩個不同的ssh-key
ssh-keygen -t rsa -C "xxx@xxx.xxx" -f ~/.ssh/id_rsa_my
ssh-keygen -t rsa -C "yyy@yyy.yyy" -f ~/.ssh/id_rsa_work
  • Step 2設(shè)置ssh key代理
ssh-add -l

# 如果提示:Could not open a connection to your authentication agent.
# 鍵入下述命令:
exec ssh-agent bash
  • Step 3:添加私鑰
ssh-add ~/.ssh/id_rsa_my
ssh-add ~/.ssh/id_rsa_work

# 鍵入上面的ssh-add -l可以查看所有ssh-key代理
# 鍵入ssh-add -D 可以刪除所有代理
  • Step 4:把公鑰(.pub)內(nèi)容復(fù)制到你遠(yuǎn)程倉庫的里

  • Step 5:添加編輯配置文件config

# bash里可以用touch新建,ubuntu里可以用gedit~
vim ~/.ssh/config

# 文件內(nèi)容
# work
Host gitee
    HostName gitee.com
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/id_rsa_work
    user git
# my
Host github
    HostName github.com
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/id_rsa_my
    user git
    
# 配置文件參數(shù)
# Host:對識別的模式,進(jìn)行配置對應(yīng)的的主機(jī)名和ssh文件
# HostName:登錄主機(jī)的主機(jī)名
# PreferredAuthentications:設(shè)置登錄方式,publickey公鑰,改成password則要輸密碼
# IdentityFile:私鑰全路徑名
# User:登錄名
    
  • Step 6:配置完成后依次鍵入下述命令進(jìn)行驗證,看下是否生效
ssh -T git@gitee.com
ssh -T git@github.com

到此就配置完畢啦~


還有一點

對了,有些小伙伴會把這個ssh-key和提交代碼的人混淆,因為在配置ssh-key的命令
后面跟了一串郵箱,以為這就是提交author的郵箱,其實不然,這個東西是通過
git config命令進(jìn)行設(shè)置的!git服務(wù)器會根據(jù)配置文件的user.email和user.email
來設(shè)置提交者的信息!

git config user.name "CoderPig" //用戶名
git config user.email  "coderpig@xxx.com"   //郵箱

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,619評論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,155評論 3 425
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,635評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,539評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,255評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,646評論 1 326
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,655評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,838評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,399評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,146評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,338評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,893評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,565評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,983評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,257評論 1 292
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,059評論 3 397
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,296評論 2 376

推薦閱讀更多精彩內(nèi)容

  • baby暉閱讀 193評論 0 1
  • 現(xiàn)在,坐在動車上,耳機(jī)里播著梁靜茹的《為你我受冷風(fēng)吹》,從福州往廈門趕,車窗飛快移動,窗外的原野撲面而來,又倏忽遠(yuǎn)...
    b0c44b601fe8閱讀 226評論 0 0