设置ssh免密码登陆linux的配置步骤

96
shaarawy18
0.1 2016.10.27 11:29* 字数 461

手边的机器是装有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

此时不需要再输入密码就可以访问远程服务器

日记本