最近我們在代碼托管平台上使用SSH的方式下拉代碼,通常是用一個ssh key來拉取所有托管平台的代碼,如碼雲,GitHub、GitLab等,但是總用一個不是太好。會有安全風險,這就需要為每個托管平台設置單獨的SSH-key
下面我們下簡單介紹一下如何創建多個SSH Key並且使用下拉代碼。
第一步、生成SSH-Key
Windows建議使用Git bash操作
Linux、mac用戶使用默認終端即可
- 生成第一個SSH-Key
$ ssh-keygen -t rsa -C "你的郵箱” -f ~/.ssh/id_rsa_one
- 生成第二個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