Debian SSH密钥生成(详细教程:使用ssh-keygen命令配置安全远程登录)

在现代 Linux 系统管理中,使用 SSH 密钥认证 是比传统密码更安全、更高效的远程登录方式。本文将手把手教你如何在 Debian 系统中使用 ssh-keygen 命令生成 SSH 密钥对,并完成基本配置。无论你是刚接触 Linux 的小白,还是希望巩固基础知识的用户,都能轻松掌握。

什么是 SSH 密钥?

SSH(Secure Shell)是一种加密网络协议,用于安全地访问远程服务器。传统的 SSH 登录使用用户名和密码,但这种方式容易受到暴力破解攻击。而 SSH 密钥认证 使用一对密钥:一个私钥 (保存在本地,绝不外泄)和一个公钥(上传到服务器)。只有拥有对应私钥的用户才能成功登录,大大提升了安全性。

准备工作

确保你的 Debian 系统已安装 OpenSSH 客户端。大多数 Debian 发行版默认已包含。如未安装,可运行以下命令:

复制代码
sudo apt updatesudo apt install openssh-client -y

步骤一:使用 ssh-keygen 生成 SSH 密钥对

打开终端,输入以下命令:

复制代码
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

参数说明:

  • -t rsa:指定密钥类型为 RSA(目前最常用)
  • -b 4096:指定密钥长度为 4096 位(比默认的 2048 更安全)
  • -C "your_email@example.com":添加注释(通常用邮箱,便于识别)

执行后,系统会提示你选择密钥保存位置(默认为 ~/.ssh/id_rsa),直接按回车使用默认路径即可。

复制代码
Enter file in which to save the key (/home/username/.ssh/id_rsa): 

接着,系统会询问是否设置密码短语(passphrase)。这是一个额外的安全层:即使私钥被盗,没有密码也无法使用。如果你是自动化脚本使用,可留空;否则建议设置。

复制代码
Enter passphrase (empty for no passphrase): Enter same passphrase again: 

完成后,你会看到类似如下输出:

复制代码
Your identification has been saved in /home/username/.ssh/id_rsaYour public key has been saved in /home/username/.ssh/id_rsa.pubThe key fingerprint is:SHA256:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx your_email@example.comThe key's randomart image is:+---[RSA 4096]----+|                 ||        o        ||       + o       ||      . * .      ||     o S = .     ||    . + * +      ||     . = O o     ||      . + B E    ||       .o*o+     |+----[SHA256]-----+

步骤二:查看并复制公钥

公钥文件位于 ~/.ssh/id_rsa.pub。使用以下命令查看内容:

复制代码
cat ~/.ssh/id_rsa.pub

输出结果是一长串以 ssh-rsa AAAAB3... 开头的字符串。请完整复制它,稍后要粘贴到远程服务器的 ~/.ssh/authorized_keys 文件中。

步骤三:将公钥上传到远程服务器

最简单的方法是使用 ssh-copy-id 命令(Debian 默认已安装):

复制代码
ssh-copy-id user@remote_host

系统会提示你输入远程服务器的密码。成功后,公钥将自动添加到服务器的 ~/.ssh/authorized_keys 中。

现在,你可以尝试 SSH 登录,如果设置了密码短语,则需输入;否则将直接登录,无需密码!

常见问题与安全建议

  • 私钥(id_rsa)必须严格保密,不要分享或上传到任何公共平台。
  • 建议定期更换 SSH 密钥,尤其是团队成员变动时。
  • 可在服务器端禁用密码登录,仅允许密钥认证,进一步提升安全性(修改 /etc/ssh/sshd_config 中的 PasswordAuthentication no)。

总结

通过本教程,你已经学会了如何在 Debian 系统中使用 ssh-keygen 命令 生成 SSH 密钥对,并配置安全的远程登录方式。这不仅提升了系统安全性,也简化了日常运维操作。记住关键词:Debian SSH密钥生成ssh-keygen命令教程SSH公钥私钥配置Linux安全远程登录,它们是你掌握这项技能的核心。

现在就去试试吧!安全从第一步开始。

来源:https://www.vpshk.cn/https://www.vpshk.cn/

相关推荐
Chengbei112 小时前
AI大模型网关存在SQL注入、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·安全·web安全·网络安全·系统安全
一拳一个娘娘腔2 小时前
告别图形化界面:基于CLI的Windows系统入侵排查与防御实战手册
windows·安全
hwscom3 小时前
Linux服务器如何进行安全加固,防止黑客攻击(Windows也适用)
linux·服务器·安全
liann1193 小时前
3.4_Linux 应急响应排查速查命令表
linux·运维·服务器·安全·网络安全·系统安全
孪生质数-3 小时前
Linux高危漏洞通报Copy Fail - CVE-2026-31431
linux·运维·服务器·ubuntu·网络安全·debian·cve-2026-31431
一拳一个娘娘腔4 小时前
攻防视角下的Windows凭证提取技术演进(2024-2026)
windows·安全
aaaffaewrerewrwer4 小时前
免费在线 AVIF 转 WebP 工具:浏览器端批量转换,无需上传更安全
安全·个人开发
@insist1234 小时前
信息安全工程师-入侵检测系统核心原理与体系架构
安全·架构·软考·信息安全工程师·软件水平考试
薛定e的猫咪5 小时前
OOD 感知决策与可信强化学习:从置信度评估到安全回退
人工智能·安全·机器学习·开源
Chockmans5 小时前
春秋云境CVE-2021-3019
安全·web安全·网络安全·网络攻击模型·安全威胁分析·春秋云境·cve-2021-3019