Mac多個Git賬戶配置

轉(zhuǎn)載Mac多個Git賬戶配置

概述

代碼管理工具從流行的CVS,到SVN,到如今的Git, 尤其是Github的存在,加之git在代碼管理的種種優(yōu)勢,git已經(jīng)被越來越多的程序員喜愛。在日常開發(fā)中,我們可能面臨著這樣的尷尬:公司本身有g(shù)it服務(wù)器,管理自己的代碼。愛折騰的程序員,可在各大第三方代碼管理平臺,github, coding.net, 碼云,也有著自己的賬號,對于github,可能也有兩個賬號;這是就需要配置多個SSH, 為了方便在一臺電腦上對多個git倉庫提交代碼,現(xiàn)在將其總結(jié)如下

具體操作

SSH key 可以讓你在你的電腦和 Git 服務(wù)器之間建立安全的加密連接。一般你的ssh key存儲在 這個目錄下/Users/{username}/.ssh

cd /Users/{accountname}/.ssh

查看.ssh目錄會有這樣幾個文件

-rw-r--r--@ 1 {username}  staff   280B  8 30 15:12 config    
-rw-------  1 {username}  staff   3.2K  8 29 17:42 id_rsa
-rw-r--r--  1 {username}  staff   748B  8 29 17:42 id_rsa.pub
-rw-------  1 {username}  staff   3.2K  8 29 14:31 id_rsa_github
-rw-r--r--  1 {username}  staff   748B  8 29 14:31 id_rsa_github.pub
-rw-------  1 {username}  staff   1.6K  8 30 15:32 id_rsa_gitlab
-rw-r--r--  1 {username}  staff   397B  8 30 15:32 id_rsa_gitlab.pub
-rw-r--r--@ 1 {username}  staff   1.5K  9  2 10:06 known_hosts

如果你的目錄下,沒有你的目錄下沒有這些文件,沒關(guān)系,下面將詳細(xì)講解這些文件的作用,以及如何生成
由于筆者已經(jīng)配置過自己github和公司gitlab,所以會比較多,這里不必在意,現(xiàn)在我就碼云為例,說明詳細(xì)配置

生成 SSH key
ssh-keygen -t rsa -C "xxx@xx.com"
輸入上述命令,點(diǎn)擊回車后,會出現(xiàn)以下提示
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/{username}/.ssh/id_rsa):

這里是提示你生成的ssh key 的存儲路徑和名稱;如果你是簡單的配置一個賬號,直接回車,自動取默認(rèn)路徑和名稱。如何你是為多個git賬號配置私鑰/公鑰,你需要自己指定路徑和名稱,筆者用的是id_rsa_oschina,名稱可自己定義,具體如下:

Generating public/private rsa key pair.  
Enter file in which to save the key (/Users/{username}/.ssh/id_rsa): /Users/{username}/.ssh/id_rsa_oschina

繼續(xù)回車

Enter passphrase (empty for no passphrase):
Enter same passphrase again:

這里取默認(rèn)值,回車即可,最后出現(xiàn)如下圖的回顯,就說明你配置成功了

Your identification has been saved in /Users/{username}/.ssh/id_rsa_oschina.
Your public key has been saved in /Users/{username}/.ssh/id_rsa_oschina.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]-----+

將生成的公鑰拷貝到剪貼板上,到git管理頁面貼入即可
pbcopy < ~/.ssh/id_rsa_oschina.pub

其中id_rsa_oschina.pub, 就是你剛才輸入的名稱
oschina配置:

oschina圖片

測試連接是否成功
ssh -T git@git.oschina.net

若返回

Welcome to Git@OSC, yourname!

則證明添加成功。

若返回

The authenticity of host 'git.oschina.net (116.211.167.152)' can't be established.
ECDSA key fingerprint is SHA256:FQGC9Kn/eye1W8icdBgrQp+KkGYoFgbVr17bmjey0Wc.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'git.oschina.net,116.211.167.152' (ECDSA) to the list of known hosts.
Permission denied (publickey).

則未成功,執(zhí)行

ssh-add ~/.ssh/id_rsa_oschina

如果ssh-add 不成功,可以直接進(jìn)入下一步
如果成功再次重復(fù)執(zhí)行這一步

至此是否已經(jīng)配置完成,答案

如果你在github等上面有兩個賬號,可能就會導(dǎo)致git提交失敗,那么這里就需要配置~/.ssh/config這個文件

打開config文件

open ~/.ssh/config

在文件中添加如下

#oschina
Host oschina  (名稱自定義)
  HostName git.oschina.net  (服務(wù)器地址)
  user git   (`git`@git.oschina.net 與 這里`git`名稱是一致的,也可自定義,但不建議修改)
  IdentityFile ~/.ssh/id_rsa_oschina (密鑰存儲路徑)

QA

Q: 按照上述步驟執(zhí)行了,仍然Permission denied (publickey)

試如下方案:

  • 清空~/.ssh/known_hosts文件
  • 執(zhí)行ssh-add -D(刪除所有), 再次執(zhí)行ssh-add -A(添加所有)

Q: 此次配置成功后,待下次重新啟動電腦后,git提交又提示Permission denied (publickey)

  • 每次重新執(zhí)行ssh-add -A
  • 每次重新執(zhí)行嫌麻煩 ,ssh-add -A -K,添加到鑰匙串內(nèi),這樣下次如果沒有知道密鑰,那么則會自動取鑰匙中存取的密鑰

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賬戶, 以前使用一個登陸并管理代碼,切換另一個賬號管理代碼時, 鑰匙串存儲仍然是第一個用戶的密碼
  • 執(zhí)行git credential-osxkeychain erase

參考

GitHub Help

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

相關(guān)閱讀更多精彩內(nèi)容

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