Git高級之配置多個SSH key


最近我們在代碼托管平台上使用SSH的方式下拉代碼,通常是用一個ssh key來拉取所有托管平台的代碼,如碼雲,GitHub、GitLab等,但是總用一個不是太好。會有安全風險,這就需要為每個托管平台設置單獨的SSH-key

下面我們下簡單介紹一下如何創建多個SSH Key並且使用下拉代碼。

第一步、生成SSH-Key

Windows建議使用Git bash操作

Linux、mac用戶使用默認終端即可

  1. 生成第一個SSH-Key
$ ssh-keygen -t rsa -C "你的郵箱” -f ~/.ssh/id_rsa_one
  1. 生成第二個SSH-Key
$ ssh-keygen -t rsa -C ""你的郵箱”” -f ~/.ssh/id_rsa_two

創建完成之后 我們在.ssh的根目錄下可以看到文件

  • WindowsSSH 目錄
C:\Users\Administrator\.ssh
  • Linux、macSSH 目錄
直接 cd ~/.ssh 即可進入

此時,.ssh目錄下應該有4個文件:id_rsa_one和id_rsa_one.pub,id_rsa_two和id_rsa_two.pub

第二步、添加私鑰

在終端中執行

ssh-add ~/.ssh/id_rsa_one 
ssh-add ~/.ssh/id_rsa_two

如果執行ssh-add時提示 Could not open a connection to your authentication agent

可以先執行命令:

ssh-agent bash

然后再重新運行ssh-add命令即可

添加成功會出現提示:

Identity added 等字樣

第三步、查看私鑰列表是否存在

ssh-add -l

當我們可以看到2條私鑰的時候就證明安裝成功了,別急還沒有完

第四步 修改配置文件config

若.ssh目錄(就是私鑰所在的文件夾)下無config文件,那么創建

touch config
打開 config 文件 配置如下格式 這里要注意 IdentityFile 后面對應的是 本地ssh key文件路徑
# gitee
Host gitee.com
HostName gitee.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_one
# github
Host github.com
HostName github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_two

第五步 用ssh命令測試驗證

ssh -T git@gitee.com
ssh -T git@github.com

驗證通過后即可愉快的clone代碼了

附:

清空私鑰列表

$ ssh-add -D

有問題請在下方留言或者加入星球


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM