如果通过 SSH 公钥密钥方式登录VPS服务器?
1. 在服务器VPS生成公钥密钥
[root@host ~]$ ssh-keygen <== 建立密钥对
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/abc): <== 输入abc(任意名称皆可),则会成abc对应的私钥和公钥
Created directory '/root/.ssh'.
Enter passphrase (empty for no passphrase): <== 输入密钥锁码,或直接按 Enter 留空
Enter same passphrase again: <== 再输入一遍密钥锁码
Your identification has been saved in /root/.ssh/abc. <== 私钥
Your public key has been saved in /root/.ssh/abc.pub. <== 公钥
The key fingerprint is:
xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:08 root@170.x.x.x
密钥锁码在使用私钥时必须输入,这样就可以保护私钥不被盗用。当然,也可以留空,实现无密码登录。
现在,在 root 用户的家目录中生成了一个 .ssh 的隐藏目录,内含两个密钥文件。abc 为私钥,abc.pub 为公钥。
2. 在服务器上安装公钥
键入以下命令,在服务器上安装公钥:
[root@host ~]$ cd .ssh
[root@host .ssh]$ cat abc.pub >> authorized_keys
如此便完成了公钥的安装。为了确保连接成功,请保证以下文件权限正确:
[root@host .ssh]$ chmod 600 authorized_keys
[root@host .ssh]$ chmod 700 ~/.ssh
3. 设置 SSH,打开密钥登录功能
- 3.1 编辑 /etc/ssh/sshd_config 文件
进行如下设置:
RSAAuthentication yes
PubkeyAuthentication yes
另外,请留意 root 用户能否通过 SSH 登录:
PermitRootLogin yes
当你完成全部设置,并以密钥方式登录成功后,再禁用密码登录:
PasswordAuthentication no
最后,重启 SSH 服务:
[root@host .ssh]$ service sshd restart
- 3.2 如果你用的是wdcp,那么上述设置在管理界面:安全管理--》ssh管理里进行设置。
4. 配置本地ssh config文件,并登录
- 4.1 如果你用的mac,那么使用下面的方式登录
把服务器上生成的私钥下载下来,放在~/.ssh/文件夹里,然后vi ~/.ssh/config,在里面进行如下设置:
host vps
HostName 100.*.*.8
Port ***
User root
IdentityFile~/.ssh/abc
然后,在终端里输入:
ssh vps
- 4.2 如果你用的windows,那么需要使用Putty等工具,具体可查看这篇文章。
大功告成,成功登录了vps服务器。:)