Git拾遺:一機多SSH-Key管理
Git拾遺:一機多SSH-Key管理
標籤: 2018
一句話概括本文:
在需要用到多個ssh-key的場景,通過配置config檔案解決此問題。
引言:
關於Git的使用總結以前已經寫過一篇文章了:小豬的Git使用總結,
應付日常開發基本夠用了,但在實際開發中,會遇到各種各樣的問題。
比如我司最近把專案都從自己的Gitlab伺服器上遷移到碼雲上,就遇到
了一個問題:多個SSH-key管理的問題。一般來講呢,一個ssh-key是
可以用在多個Git伺服器的,這東西只是用於加密訪問,只要伺服器上的
公鑰能夠和本地的私鑰配對就可以了。但是呢,不同的賬號不能用一樣的
公鑰!
如果你用過Git提交程式碼,相信你對SSH Key不會陌生,在Clone專案的
時候可以看到有兩種可選協議 HTTPS和SSH:
連結是這樣的:
https://gitee.com/xxx/YYY.git
git@gitee.com:xxx/YYY.git
走Https協議,可以clone任何專案,但是Push時需要輸入賬號密碼
走ssh協議,必須是專案的擁有者和管理員才能clone,配置了ssh-key的話,推送的
時候,不用輸入賬號密碼(前提是你在配置ssh-key的時候沒有設定密碼),直接就能提交。
可以通過下面簡單的命令建立一個ssh-key
cd ~/.ssh
# 如果路徑不存在的話,鍵入下述命令建立ssh資料夾
mkdir ~/.ssh
# 鍵入下述命令生成ssh-key的公鑰和私鑰
# 會讓你依次輸入檔名,密碼,密碼,結束後預設生成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建立完後,需要開啟公鑰,複製裡面的內容,然後貼到你Gitlab,Github,
碼雲的SSH-Key配置頁,比如我的:
配置成功後,命令列鍵入:
ssh -T git@gitee.com
如果出現這樣的提示,說明配置完成~
問題來了
一般來講,除了公司倉庫外,開發者一般也會有自己的Git倉庫,比如我有自己的
Github,碼雲,coding.net,如果是一樣的郵箱,那還好,
可以git remote add 命令新增分支別名,比如:
git remote add origin xxx@xxx.git
git remote add osc yyy@yyy.git
然後push或者pull的時候手動指定遠端倉庫對應的分支即可
git push origin master
git pull osc master
但是問題來了,公司郵箱和自己郵箱不一樣,如果你直接執行
上面那個ssh-keygen -t rsa -C “xxx@xxx.cn”建立是會覆蓋掉原先的ssh-key,
然後出現公司專案能Push,自己專案不能Push的問題。
解決方法如下:
- Step 1:假設我有一個自己的賬號和公司賬號,通過下述命令可以建立兩個不同的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:設定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)內容複製到你遠端倉庫的裡
Step 5:新增編輯配置檔案config
# bash裡可以用touch新建,ubuntu裡可以用gedit~
vim ~/.ssh/config
# 檔案內容
# 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
# 配置檔案引數
# Host:對識別的模式,進行配置對應的的主機名和ssh檔案
# HostName:登入主機的主機名
# PreferredAuthentications:設定登入方式,publickey公鑰,改成password則要輸密碼
# IdentityFile:私鑰全路徑名
# User:登入名
- Step 6:配置完成後依次鍵入下述命令進行驗證,看下是否生效
ssh -T git@gitee.com
ssh -T git@github.com
到此就配置完畢啦~
還有一點
對了,有些小夥伴會把這個ssh-key和提交程式碼的人混淆,因為在配置ssh-key的命令
後面跟了一串郵箱,以為這就是提交author的郵箱,其實不然,這個東西是通過
git config命令進行設定的!git伺服器會根據配置檔案的user.email和user.email
來設定提交者的資訊!
git config user.name "CoderPig" //使用者名稱
git config user.email "coderpig@xxx.com" //郵箱
相關文章
- 關於git專案中多ssh-key管理Git
- 關於git的ssh-key:解決本地多個ssh-key的問題Git
- [MASM拾遺]OffsetASM
- 前端技能拾遺前端
- Java Web 拾遺JavaWeb
- 物件導向拾遺物件
- OrchardCore Headless建站拾遺
- [Go]Go 語言基礎拾遺(一)Go
- MIT 6.824拾遺(一)聊聊basic-paxosMIT
- 在windows平臺上如何做到git多ssh-key相容WindowsGit
- Confluence 容器化使用拾遺
- docker拾遺-之再入坑Docker
- 容器化 Confluence 使用拾遺
- golang拾遺:嵌入型別Golang型別
- Vue.js基礎拾遺Vue.js
- PHP 使用 Kafka 安裝拾遺PHPKafka
- AS拾遺--向PM學習二
- golang拾遺:指標和介面Golang指標
- 老工具 fiddler-使用拾遺及一些技巧
- golang拾遺:實現一個不可複製型別Golang型別
- 課時39:類與物件:拾遺物件
- C#拾遺補闕【01】:字串C#字串
- c++語法拾遺,一些細節與特性C++
- 【105天】前端碎片知識拾遺00003前端
- 【106天】前端碎片知識拾遺00004前端
- JAVA 拾遺 — CPU Cache 與快取行Java快取
- Zepto核心模組之工具方法拾遺
- JSON實戰拾遺之數字精度JSON
- mysql 拾遺提高(函式、事務、索引)MySql函式索引
- React拾遺:Render Props及其使用場景React
- 前端拾遺--javascript-ES6基礎前端JavaScript
- (零) React Native 專案開發拾遺React Native
- iOS拾遺—— Assets Catalogs 與 I/O 優化iOS優化
- JAVA拾遺 — JMH與8個測試陷阱Java
- 基礎拾遺---委託,匿名函式,lambda函式
- [C#.NET拾遺補漏]01:字串操作C#字串
- 2萬字 | 前端基礎拾遺90問前端
- golang拾遺:為什麼我們需要泛型Golang泛型