很多网上免ssh密码使用git的命令都没有考虑到多个公钥密钥的情况,这里搜集并整理一下管理多个ssh公钥密钥的步骤。
首先生成公钥和密钥,默认情况公钥的文件名比密钥末尾多.pub,下面以管理coding.net和github.com两个git仓库的ssh公钥密钥为例(如果是在windows下,请安装git客户端然后使用git bash来键入下面的命令;如果是在linux下,则直接使用终端即可):
1 2 |
ssh-keygen -t rsa -f ~/.ssh/id_rsa.coding -C "Key for coding.net" ssh-keygen -t rsa -f ~/.ssh/id_rsa.github -C "Key for GitHub stuff" |
这个命令直接通过-f参数指定了密钥和公钥的文件名,比如-f ~/.ssh/id_rsa.coding,其生产的密钥为~/.ssh/id_rsa.coding,公钥为~/.ssh/id_rsa.coding.pub,生成好了公钥和密钥后,把公钥文件中的内容追加到~/.ssh/authorized_keys文件的末尾,同理github的公钥密钥的生成方式类似。注意追加前authorized_keys文件的末尾需要有个换行符。追加后的效果可能是这样的:
1 2 |
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是在Settings–>SSH Keys里面
当有多个ssh密钥需要管理时,一定要修改config文件的权限,否则你配置后仍然时无效的
1 2 |
touch ~/.ssh/config chmod 600 ~/.ssh/config |
~/.ssh/config文件的内容为:
1 2 3 4 5 6 7 |
Host github.com IdentityFile ~/.ssh/id_rsa.github User git Host git.coding.net IdentityFile ~/.ssh/id_rsa.coding User git |
其中User后面的值为你访问的git ssh地址的@之前的部分,比如:git@github.com:dongritengfei/beego.git的@前面是git,所以User后面的值为git。Host就是你的git仓库的域名或者IP。
然后是用这个命令来测试是否配置ok
1 2 |
ssh -T git@github.com Welcome to GitHub, you name! |
如果你看到这个就说明你ok了,如果你看到下面的样子:
1 |
Bad owner or permissions on /home/admin/.ssh/config |
那你需要执行:
1 |
chmod 600 ~/.ssh/config |
然后再试试应该就可以了。
其他
上面的说的SSH的情况,如果你使用的HTTPS的方式clone代码的话,需要免登就需要这样:http://www.akmumu.com/2015/06/02/360.html