手边的机器是装有OSX操作系统的Macbook Pro,现在我想通过终端ssh远程访问装有linux操作系统的服务器,通过以下步骤设置免密码访问
1.生成私钥文件
在客户端终端下输入以下命令
ssh-keygen -t rsa
每次执行 ssh-keygen -t rsa 产生的私钥文件都会不同
如果文件"~/.ssh/id_rsa"存在,会提示是否覆盖该文件,此时可选择"n"不覆盖该文件而使用已有的id_rsa文件
如果选择"y"则会重新生成"~/.ssh/id_rsa"文件。接下来会提示输入passphrase,回车确定使用空的passphrase,再次回车确认(这里也可以输出passphrase,相当于ssh时登录的密码)。然后会重新生成id_rsa文件和id_rsa.pub文件(在~/.ssh目录下)
2.在终端中执行scp远程拷贝命令
scp /Users/shaarawy18/.ssh/id_rsa.pub root@192.168.83.11:~/.ssh
将生成的id_rsa.pub文件拷贝到远程服务器的 ~/.ssh 目录下
此时还需要输入root用户密码进行访问
3.将公钥追加到授权KEY里面
在服务器终端下输入下面的命令
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
如果远程服务器上已经存在"~/.ssh/authorized_keys"文件,那么需要编辑服务器上"~/.ssh/authorized_keys"文件,将客户端机器上的"id_rsa.pub"文件内容追加到"~/.ssh/authorized_keys"文件中。
如果服务器上没有"~/.ssh/authorized_keys"文件,执行下面这条命令
cp id_rsa.pub authorized_keys
即将公钥复制为authorized_keys文件
4.测试是否配置生效
command+N新建终端窗口,输入ssh登录命令
ssh root@192.168.83.11
此时不需要再输入密码就可以访问远程服务器