1. 什么是SSH
SSH是Secure Shell的简称,是一种安全的网络传输协议,用于在不安全的网络中提供加密的远程登录和执行命令。SSH协议建立在传统的Telnet协议基础上,通过加密和身份验证解决了网络传输中的安全问题。
SSH协议是目前最常用的远程登录协议之一,主要用于在Linux系统中进行远程连接和管理,可以通过SSH协议在本地计算机上登录远程服务器,执行命令,上传或下载文件等操作。
2. SSH的公钥认证
SSH协议中,身份验证是确保合法用户访问系统的重要环节。SSH提供了几种身份验证方式,如用户名/密码、密钥对等。其中,公钥认证是一种更安全和便捷的身份验证方式。
公钥认证的原理是:用户将自己生成的一对密钥中的公钥部分安装到要登录的服务器上,而将私钥保留在本地。当用户使用SSH客户端连接远程服务器时,客户端会向服务器发送一个随机数作为挑战,服务器将该随机数使用用户的公钥进行加密,并将加密后的结果返回给客户端。客户端使用本地的私钥解密服务器返回的结果,然后将解密后的结果发送给服务器。服务器通过比较收到的结果和之前加密的结果确认用户的身份。
2.1 生成SSH密钥对
要使用公钥认证,首先需要在本地计算机上生成一对SSH密钥。可以使用SSH客户端自带的工具来生成密钥对,常用的工具有OpenSSH和PuTTY。
以OpenSSH为例,可以通过以下命令生成一对密钥:
ssh-keygen -t rsa
执行上述命令后,系统会询问密钥的保存路径和密码等信息。可以选择默认路径和设置密码,也可以根据需要修改。
成功生成密钥对后,会在默认保存路径(一般为~/.ssh)下生成两个文件:id_rsa和id_rsa.pub,分别对应私钥和公钥。
2.2 安装公钥到远程服务器
生成了密钥对后,需要将公钥安装到要登录的远程服务器上。可以使用SSH客户端提供的命令将公钥上传到服务器。
ssh-copy-id user@remote_server
执行上述命令时,需要替换user和remote_server为实际的用户名和远程服务器的地址。
在运行命令后,会提示输入远程服务器的密码。输入密码后,客户端将会将公钥上传到远程服务器的用户目录下的.ssh/authorized_keys文件中。
如果一切顺利,此时再次使用SSH客户端连接远程服务器时,将不需要输入密码,即可完成身份验证。
3. Linux下配置SSH公钥认证
上面介绍了公钥认证的原理和生成密钥对的步骤,接下来将介绍如何在Linux系统中配置SSH公钥认证。
3.1 修改SSH配置文件
SSH的配置文件位于/etc/ssh/sshd_config,可以使用文本编辑器打开文件进行修改。
sudo vi /etc/ssh/sshd_config
找到文件中的以下行,并将其取消注释:
#PubkeyAuthentication yes
此行用于启用公钥认证功能。
另外,可以修改以下行以增加安全性:
#PasswordAuthentication yes
将上述行改为:
PasswordAuthentication no
上述行的作用是禁用密码认证,只允许使用公钥认证。
完成以上修改后,保存配置文件并退出编辑器。
3.2 重启SSH服务
修改SSH配置文件后,需要重启SSH服务使新的配置生效。
sudo service ssh restart
执行以上命令后,SSH服务将会重新启动,加载新的配置。
4. 使用SSH公钥认证进行登录
在完成SSH公钥认证的配置后,即可使用SSH客户端进行登录。使用SSH命令进行登录的方式如下:
ssh user@remote_server
此命令中,user和remote_server分别代表实际的用户名和远程服务器的地址。执行命令后,如果一切顺利,将直接进入远程服务器系统,无需密码验证。
5. 总结
SSH公钥认证是一种安全且便捷的身份验证方式。通过生成一对密钥,将公钥安装到远程服务器,即可实现免密码登录。在Linux系统中,配置SSH公钥认证需要修改SSH配置文件,并重启SSH服务。配置完成后,即可使用SSH客户端进行登录操作。
SSH公钥认证可以提高系统的安全性,避免了明文传输密码的风险,同时也方便了用户的操作。在实际应用中,建议尽可能使用公钥认证来进行SSH登录,以加强系统的防护。