在当今网络环境下,Linux安全是每个运维人员和开发者都必须重视的课题。传统的密码登录方式存在被暴力破解的风险,而采用SSH密钥登录可以极大提升服务器的安全性。本文将手把手教你如何配置公钥认证,并最终禁用密码登录,让你的服务器远离黑客攻击。
密码登录虽然简单,但存在诸多弱点:弱口令、密码泄露、暴力破解等。而SSH密钥登录基于非对称加密,客户端持有私钥,服务器存储公钥,只有配对的私钥才能登录,几乎无法被暴力破解。这是Linux安全基线配置的重要一环。
在客户端(你的本地电脑)执行以下命令生成密钥对:
ssh-keygen -t rsa -b 4096 -C "your_email@example.com" 参数说明:-t rsa指定算法,-b 4096指定长度(更安全),-C添加注释。按提示设置保存路径和密码短语(可选)。生成后默认在~/.ssh/下得到id_rsa(私钥)和id_rsa.pub(公钥)。
使用ssh-copy-id命令自动将公钥添加到服务器的~/.ssh/authorized_keys文件中:
ssh-copy-id user@server_ip 如果该命令不可用,也可以手动复制:
cat ~/.ssh/id_rsa.pub | ssh user@server_ip "mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys" 编辑服务器上的SSH配置文件/etc/ssh/sshd_config(需要root权限):
sudo vim /etc/ssh/sshd_config 确保或修改以下配置:
PubkeyAuthentication yes # 启用公钥认证PasswordAuthentication no # 禁用密码登录(关键步骤!)ChallengeResponseAuthentication noPermitRootLogin prohibit-password # 禁止root使用密码登录(可选但推荐) 保存后重启SSH服务:sudo systemctl restart sshd 或 sudo service ssh restart。
保持当前SSH会话不退出,另开终端尝试登录:
ssh user@server_ip 如果配置正确,你将直接登录而无需输入密码(除非你设置了密钥密码短语)。
通过以上步骤,你成功实现了SSH密钥登录并禁用密码登录,大大增强了服务器的Linux安全。记住,公钥认证是现代服务器管理的基石,配合其他安全措施(如防火墙、fail2ban等)可以构建更坚固的防线。希望这篇指南能帮助你在Linux安全的道路上迈出坚实的一步。
关键词:Linux安全、SSH密钥登录、公钥认证、禁用密码登录
本文由主机测评网于2026-03-10发表在主机测评网_免费VPS_免费云服务器_免费独立服务器,如有疑问,请联系我们。
本文链接:https://vpshk.cn/20260329985.html