如何使用密钥身份验证在CentOS服务器上实现更安全的SSH登录

2023年 8月 2日 14.5k 0

如何使用密钥身份验证在CentOS服务器上实现更安全的SSH登录

在服务器管理中,保障系统安全至关重要。SSH(Secure Shell)是一种加密网络协议,用于远程登录Linux和UNIX服务器。为了进一步加强服务器的安全性,我们可以使用密钥身份验证来代替密码登录。本文将介绍如何在CentOS服务器上实现更安全的SSH登录,并提供相应的代码示例。

第一步:生成密钥对

首先,在本地机器上生成密钥对。打开终端窗口,输入以下命令:

ssh-keygen -t rsa

登录后复制

此命令将使用RSA算法生成密钥对。按Enter键确认密钥保存路径和文件名。随后,系统会要求您输入密钥的密码。您可以选择设置密码或者留空,然后按Enter键继续生成密钥。

生成成功后,您将在指定路径下找到两个文件:id_rsa(私钥)和id_rsa.pub(公钥)。

第二步:将公钥复制到服务器

接下来,将公钥复制到CentOS服务器上。使用以下命令将公钥复制到服务器:

ssh-copy-id user@server_ip_address

登录后复制

将“user”替换为您在CentOS服务器上的用户名,将“server_ip_address”替换为服务器的IP地址。系统会要求您输入密码以进行身份验证。

成功复制公钥后,您将得到以下输出:

Number of key(s) added: 1

登录后复制

第三步:配置SSH服务

在服务器上,打开SSH配置文件进行设置。使用以下命令打开文件:

sudo vi /etc/ssh/sshd_config

登录后复制

找到并确保以下行被取消注释并设置如下值:

PubkeyAuthentication yes
PasswordAuthentication no
PermitRootLogin no

登录后复制

取消注释表示允许使用公钥身份验证,禁用密码身份验证,以及禁止root用户直接登录。修改后,保存并关闭文件。

接下来,重启SSH服务以应用更改:

sudo systemctl restart sshd

登录后复制

第四步:测试SSH登录

现在,您已经完成了配置。您可以使用以下命令测试SSH登录是否成功:

ssh user@server_ip_address

登录后复制

将“user”替换为您的用户名,将“server_ip_address”替换为服务器的IP地址。系统会尝试使用您的私钥进行身份验证。

如果一切设置正确,您将成功登录到CentOS服务器上,而无需输入密码。

额外提示:

  • 为了进一步加强服务器安全性,您可以使用Passphrase来保护私钥。这样,即使私钥被盗,也无法通过身份验证。
  • 确保私钥文件的权限设置为600,即只有所有者可读写。
  • 使用不同的密钥对来为多个用户进行身份验证。
  • 定期更换密钥对,以增加安全性。

总结:

使用密钥身份验证能够大大提高服务器的安全性,防止恶意登录和密码暴力破解。本文介绍了在CentOS服务器上实现更安全的SSH登录的方法,并提供了相应的代码示例。通过遵循这些步骤,您可以轻松地设置服务器的密钥身份验证,保障系统的安全。

以上就是如何使用密钥身份验证在CentOS服务器上实现更安全的SSH登录的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

服务器端口转发,带你了解服务器端口转发
服务器开放端口,服务器开放端口的步骤
产品推荐:7月受欢迎AI容器镜像来了,有Qwen系列大模型镜像
如何使用 WinGet 下载 Microsoft Store 应用
百度搜索:蓝易云 – 熟悉ubuntu apt-get命令详解
百度搜索:蓝易云 – 域名解析成功但ping不通解决方案

发布评论