很多网上免ssh密码使用git的命令都没有考虑到多个公钥密钥的情况,这里搜集并整理一下管理多个ssh公钥密钥的步骤。
首先生成公钥和密钥,默认情况公钥的文件名比密钥末尾多.pub
ssh-keygen -t rsa -f ~/.ssh/id_rsa.work -C "Key for Work stuff"
ssh-keygen -t rsa -f ~/.ssh/id_rsa.github -C "Key for GitHub stuff"
这个命令直接通过-f参数指定了密钥和公钥的文件名,比如-f ~/.ssh/id_rsa.work,其生产的密钥为~/.ssh/id_rsa.work,公钥为~/.ssh/id_rsa.work.pub,生成好了公钥和密钥后,把公钥文件中的内容追加到~/.ssh/authorized_keys文件的末尾,注意追加前authorized_keys文件的末尾需要有个换行符。追加后的效果可能是这样的:
ssh-rsa AAAAB3NzaC1yc2EAAaaaaaaupeyE1NMMrb121244DwhwFLsPFiFrFb1QUwQtX2m/YSi8ELn3Vga/5AhfKKPWG+nOczWZxi0XguiyAslRiiowXaUjBYei5NHHBcAy+GiZWs4u8h3ZU7uGvwmQlqHf8tQ/I0J1RNR6nQ8Ra9882398akk23h9Hhp63EagSbpkefg7qScroq0+VZ2yfLyjUCLgxhb+Eah+r9EqQ4l%HEF;asd8hLQw449W1SzKz3hCwxFAJFKbj/n+J50vNXB3fLNeTNiq@OOIkn324n802Do5jIZGFzNrYsIRFbJVbHvIsodyXDmz6Qbqlx87xmEQ== admaaa@163.com
ssh-rsa AAAAB3NzaC1yc2EAAAaa2#@8923n(&@hfg2-hg9002nkglsdfPCBUhDN185+jyoJQRwLImRr6IOwh/LSBS1N22pO#NG3434ng90u32n@0)@#NKDLHWO:@_jqtUIBr8UzWzliM5Zcn9U/DjSjuAiP/SFg1JEoXfWSFToWQpYNbGS9VFwU83MH1iGGDUeaeHY5mAMWy57ym/+Jm/hPs1I3E+OtDT9+K1RyIGr44Ur7aWpKZ/PMgiuPUc6qfGFVP4xvRw== myyyy@gmail.com
同时把这个公钥添加到git仓库ssh key管理的地方,比如github是在
当有多个ssh密钥需要管理时,一定要修改config文件的权限,否则你配置后仍然时无效的
touch ~/.ssh/config
chmod 600 ~/.ssh/config
~/.ssh/config文件的内容为:
Host *.workdomain.com
IdentityFile ~/.ssh/id_rsa.github
User git
Host *.workdomain.com
IdentityFile ~/.ssh/id_rsa.work
User lee
其中User后面的值为你访问的git ssh地址的@之前的部分,比如:git@github.com:dongritengfei/beego.git的@前面是git,所以User后面的值为git。Host就是你的git仓库的域名或者IP。
然后是用这个命令来测试是否配置ok
ssh -T git@github.com
Welcome to GitHub, you name!
如果你看到这个就说明你ok了,如果你看到下面的样子:
Bad owner or permissions on /home/admin/.ssh/config
那你需要执行:
chmod 600 ~/.ssh/config
然后再试试应该就可以了。