如果你在配置服务器的免密登陆时出现了如下的error,那这篇文章一定会对你有帮助
(zzh是我配置的别名,如果没有配置过,后面跟的参数应该是用户名@ip地址
的格式)
报错的原因呢,其实是Windows终端和Linux终端不同,没有内置ssh-copy-id
命令
本文提供三种解决方案
正常情况下,用第一种就可以解决了,而且第一种方案也最方便
方案一 复制下面这段脚本,粘贴到Windows终端,按回车运行即可
function ssh-copy-id([string]$userAtMachine, $args){
$publicKey = "$ENV:USERPROFILE" + "/.ssh/id_rsa.pub"
if (!(Test-Path "$publicKey")){
Write-Error "ERROR: failed to open ID file '$publicKey': No such file"
}
else {
& cat "$publicKey" | ssh $args $userAtMachine "umask 077; test -d .ssh || mkdir .ssh ; cat >> .ssh/authorized_keys || exit 1"
}
}
这样以后,就可以成功使用ssh-copy-id
了
上面这段其实就是,根据ssh-copy-id
的执行逻辑来编写的shell脚本
方案二:下载一个git bash
git bash是肯定可以有ssh-copy-id
命令的,直接用就好了
顺便提一句,如果还是不行,可能是没有ssh-keygen
生成密钥
方案三 最本质的做法
ssh-copy-id的本质是把你本地的公钥添加到服务器/远程机的~/.ssh/authorized_keys
文件里
powershell不给力,那我们自己Ctrl CV就好了
ssh-keygen
生成密钥后,家目录/.ssh就会多两个文件
id_rsa
:私钥id_rsa.pub
:公钥