Git配置多賬號(hào)SSH登錄不同的服務(wù)器

一般來說在公司做項(xiàng)目,都是用公司分配的郵箱。例如通過在Git bash里面運(yùn)行git config --global命令配置全局的Git賬號(hào):

$ git config --global user.name "<name>"
$ git config --global user.email "<email>"

有時(shí)候也有例外,比如我們可能有多個(gè)通過SSH訪問的Git Repo,并且想在不同的Repo上使用不同的身份(不同的SSH key)。例如,公司基于.Net平臺(tái)的項(xiàng)目使用的是Azure DevOps上遠(yuǎn)程Git倉庫,需要使用公司的賬號(hào);私人的項(xiàng)目使用GitHub上的遠(yuǎn)程Git倉庫,需要使用個(gè)人的賬號(hào)。
這種情況可以通過下面的設(shè)置來實(shí)現(xiàn):

第一步,為每個(gè)Git服務(wù)器生成獨(dú)立的SSH key

在Git bash中使用ssh-keygen命令生成SSH key,常用參數(shù)如下:
-t指定密鑰類型為rsa
-C 指定郵箱
-f指定文件存放的路徑和名稱。在Windows系統(tǒng)里,~/.ssh就是C:\Users<當(dāng)前登錄用戶名>.ssh文件夾。
-P ''指定密碼為空。這個(gè)密碼是用于保護(hù)私鑰的,如果填入密碼,git在通信時(shí)會(huì)要求輸入密碼。
下面命令為azure devops生成SSH Key,將在~/.ssh文件夾生成id_rsa_azuredevops和帶.pub擴(kuò)展名的兩個(gè)文件:

$ ssh-keygen -t rsa -C "efrey.kong@EKStudio.com" -f ~/.ssh/id_rsa_azuredevops -P ''

下面命令為GitHub生成SSH Key,命令完成后會(huì)在~/.ssh文件夾生成id_rsa_github和id_rsa_github.pub兩個(gè)文件:

$ ssh-keygen -t rsa -C "efrey.kong@gmail.com" -f ~/.ssh/id_rsa_github -P ''

第二步,配置本地的SSH config

在~/.ssh文件夾中編輯config文件。如果沒有此文件則用記事本新建一個(gè),保存時(shí)需要注意不要.txt的擴(kuò)展名。
在文件里配置如下內(nèi)容:

#Company repo
Host ssh.dev.azure.com
HostName ssh.dev.azure.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_azuredevops

#Personal repo
Host github.com
HostName ssh.github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_github

當(dāng)Git命令需要訪問網(wǎng)絡(luò)時(shí),SSH會(huì)按照命令中指定的host(例如git clone git@host/repopath)在config中尋找匹配的host,找到后使用HostName作為實(shí)際的通信服務(wù)器名,使用IdentityFile指定的key作為密鑰同服務(wù)器通信。

第三步,將公鑰文件上傳到Git服務(wù)器

SSH Public Key上傳的過程略(參考官網(wǎng)的說明)。

上傳完成后可以用ssh -T命令驗(yàn)證下(ssh -vT 可以輸出debug信息):

$ ssh -vT git@github.com
OpenSSH_7.9p1, OpenSSL 1.1.1a  20 Nov 2018
debug1: Reading configuration data /c/Users/efrey/.ssh/config
debug1: /c/Users/efrey/.ssh/config line 16: Applying options for github.com
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: Connecting to ssh.github.com [192.30.253.123] port 22.
debug1: Connection established.
debug1: identity file /c/Users/efrey/.ssh/id_rsa_github type 0
debug1: identity file /c/Users/efrey/.ssh/id_rsa_github-cert type -1
...
debug1: Authentications that can continue: publickey
...
Hi efreykongcn! You've successfully authenticated, but GitHub does not provide shell access.
...

從debug輸出的信息中可以看到,通信使用的是id_rsa_github證書,以及已認(rèn)證的歡迎信息。

如果此時(shí)本地庫還沒有創(chuàng)建,則從服務(wù)器克隆一個(gè)本地庫:

$ git clone git@github.com:efreykongcn/PrimerRepo.git
Cloning into 'PrimerRepo'...
remote: Enumerating objects: 3, done.
remote: Counting objects: 100% (3/3), done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
Receiving objects: 100% (3/3), done.

第四步,設(shè)置項(xiàng)目Git倉庫的工作賬號(hào)

然后,在Git Repo的工作目錄下設(shè)置local user.name和user.email。
在Git Repo工作目錄位置打開Git bash進(jìn)行設(shè)置:

$ git config --local user.name "<your name>"
$ git config --local user.email "<your email>"

這樣,在項(xiàng)目里就會(huì)以這個(gè)賬號(hào)向Git倉庫提交代碼了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容