服务器怎么创建秘钥对?Linux生成SSH密钥详细步骤

服务器创建密钥对是保障远程登录安全的核心手段,其本质是利用非对称加密算法生成一对相互关联的密钥,其中公钥存放在服务器端,私钥由用户本地保管,以此实现“无密码登录”且极大提升防暴力破解能力。相比传统的密码认证,密钥对认证不仅更安全,还能有效规避弱口令风险,是服务器运维管理的标准操作规范。

服务器怎么创建秘钥对

核心原理与安全优势

在深入操作步骤之前,理解密钥对的运作机制至关重要,密钥对由公钥和私钥组成,二者一一对应。

  1. 私钥:相当于家门钥匙,必须严格保密,绝不在网络中传输。
  2. 公钥:相当于家门锁芯,放置在服务器指定位置,可以公开。

当客户端发起连接请求时,服务器会利用公钥加密一段随机字符串发送给客户端,客户端使用私钥解密后发回服务器,服务器验证解密正确性即可确认身份。 这一过程无需传输密码,即使网络被监听,私钥也不会泄露。

创建前的环境准备

在执行服务器怎么创建秘钥对的具体操作前,需确保环境配置正确,这是保障后续流程顺畅的基础。

  1. 客户端工具:Linux或MacOS系统可直接使用终端;Windows系统建议使用PowerShell或安装Git Bash,也可以使用PuTTY、Xshell等SSH客户端工具。
  2. 服务端权限:必须拥有服务器的root权限或具备sudo权限的普通用户账号。
  3. 网络连通性:确保客户端与服务器之间的22端口(SSH默认端口)网络通畅。

服务器端创建密钥对详细步骤

这是最常用且最推荐的方法,直接在服务器端生成私钥与公钥,然后将私钥下载至本地。这种方式确保了私钥在生成初期未经过不安全的网络传输。

登录服务器终端
使用SSH工具登录到目标服务器,输入密码完成登录。

执行生成命令
输入以下命令启动密钥生成程序:
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

  • -t rsa:指定使用RSA算法,兼容性最好。
  • -b 4096:指定密钥长度为4096位,安全性更高。
  • -C:添加注释,通常用于标识密钥用途或所有者。

配置密钥存储路径
系统会提示输入保存路径,默认为~/.ssh/id_rsa

  • 建议操作:直接按回车键使用默认路径,避免后续配置出错。
  • 自定义路径:若需管理多组密钥,可输入自定义路径,如~/.ssh/my_server_key

设置密钥口令
系统会提示输入口令。

服务器怎么创建秘钥对

  • 高安全场景:输入复杂的口令,即使私钥被盗,攻击者仍需破解口令才能使用。
  • 自动化运维场景:若用于脚本自动化登录,可留空直接按两次回车,实现免交互登录,但需确保服务器硬盘安全。

查看生成结果
进入.ssh目录查看文件:
ls -l ~/.ssh/
你会看到两个文件:

  • id_rsa:私钥文件,权限应为600。
  • id_rsa.pub:公钥文件,权限应为644。

配置公钥与SSH服务

生成密钥对后,必须将公钥“安装”到授权列表中,并调整SSH配置以启用密钥认证。

部署公钥至授权文件
执行以下命令,将公钥内容追加到authorized_keys文件中:
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
这一步是核心环节,authorized_keys文件是SSH服务验证客户端身份的依据。

设置文件权限
权限设置错误是导致密钥登录失败的常见原因,必须严格执行以下命令:
chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys
SSH服务对权限极其敏感,若权限过于开放(如777),服务会拒绝读取密钥文件。

修改SSH服务配置
编辑SSH配置文件/etc/ssh/sshd_config,确保以下参数设置正确:

  • PubkeyAuthentication yes:启用公钥认证。
  • PasswordAuthentication no:建议关闭密码认证,强制使用密钥登录(需确认密钥登录成功后再修改此项,防止被锁在外面)。
  • AuthorizedKeysFile .ssh/authorized_keys:指定授权文件路径。

修改完成后,重启SSH服务使配置生效:
systemctl restart sshdservice sshd restart

客户端私钥管理与登录验证

服务器端配置完成后,需将生成的私钥文件(id_rsa)安全地下载到本地客户端。

私钥的安全传输
使用SFTP工具(如FileZilla、WinSCP)将服务器上的id_rsa文件下载至本地。下载完成后,务必删除服务器端的私钥文件,仅保留公钥,遵循“私钥不出服务器”的二次防护原则,除非你需要在多客户端登录。

服务器怎么创建秘钥对

本地登录验证

  • Linux/Mac终端:执行 ssh -i /本地路径/id_rsa user@server_ip,若设置了口令,需输入口令。
  • Windows PuTTY:需使用PuTTYgen工具将下载的id_rsa转换为.ppk格式,再加载到PuTTY的Auth配置中进行连接。

验证成功标志
成功登录后,终端提示符会变更为服务器用户界面,若配置了禁用密码登录,尝试用密码登录应显示“Permission denied”。

独立见解与专业建议

在实际的运维工作中,关于服务器怎么创建秘钥对以及后续管理,存在许多容易被忽视的细节,以下是基于E-E-A-T原则的专业建议:

  1. 算法选择策略:虽然RSA-4096目前仍是主流,但在高性能或极高安全需求场景下,建议使用ED25519算法,它具有更短的密钥长度、更快的签名速度,且安全性不输给长位RSA,生成命令为:ssh-keygen -t ed25519
  2. 私钥生命周期管理:密钥对不应“一劳永逸”,建议每半年或一年轮换一次密钥对,对于离职员工的密钥,必须立即从authorized_keys中删除对应公钥。
  3. 避免使用空口令私钥:在CI/CD流水线中,为了方便常使用无口令私钥,这实际上是一个巨大的安全隐患,建议使用ssh-agent来管理有口令的私钥,既保证安全又实现自动化。

相关问答

创建密钥对后,SSH登录提示“Permission denied (publickey)”怎么办?
这是最常见的报错,通常由以下三个原因导致:

  1. 权限问题:检查服务器端.ssh目录是否为700,authorized_keys文件是否为600。
  2. SELinux拦截:在CentOS等系统中,恢复文件安全上下文可解决,执行命令restorecon -R -v ~/.ssh
  3. 错误:检查authorized_keys是否完整,确保没有多余的换行符或缺失字符。

是否可以在本地电脑生成密钥对,再上传公钥到服务器?
完全可以,且这也是一种常用方法。
操作流程为:在本地执行ssh-keygen生成密钥对,然后使用ssh-copy-id user@server_ip命令将本地公钥自动上传至服务器的authorized_keys文件中,这种方法省去了手动下载私钥的步骤,适合从单一控制机管理多台服务器的场景。

如果您在配置过程中遇到其他疑难杂症,欢迎在评论区留言交流。

首发原创文章,作者:世雄 - 原生数据库架构专家,如若转载,请注明出处:https://idctop.com/article/99541.html

(0)
上一篇 2026年3月17日 14:42
下一篇 2026年3月17日 14:43

相关推荐

  • 服务器挥泪转让了,二手服务器转让价格多少钱?

    服务器挥泪转让了,这一决策背后往往不是简单的资产处置,而是企业或个人在技术迭代、成本控制与业务转型多重压力下的战略性止损,核心结论非常明确:在云计算普及与硬件折旧极快的当下,及时出手闲置或低效的物理服务器,将其转化为流动资金或云端资源,是优化资产结构、降低运营成本的唯一正确路径,与其让设备在机房角落里贬值,不如……

    2026年3月12日
    8400
  • 服务器将配是什么意思?服务器配置选择指南

    服务器配置是保障业务稳定运行的基石,其核心逻辑在于精准的需求匹配与性能冗余的平衡,而非单纯追求硬件参数的堆砌,科学合理的配置方案能够最大化资源利用率,显著降低后期维护成本与业务中断风险,精准匹配业务场景是配置的首要原则服务器硬件选型必须建立在对业务形态深度理解的基础之上,不同类型的业务对计算、内存、存储及网络资……

    2026年3月31日
    4700
  • 服务器建了一个数据库怎么知到数据库账户密码,数据库默认账号密码是多少

    获取服务器新建数据库的账户密码,核心结论在于:优先查阅官方文档与安装日志,其次尝试默认凭证,最后通过服务器管理员权限进行重置或找回,切勿尝试非法破解, 面对服务器建了一个数据库怎么知到数据库账户密码这一问题,必须遵循合规、安全、高效的排查路径,任何绕过授权的暴力获取行为均违反安全准则,以下为分层论证的专业解决方……

    2026年4月10日
    3800
  • 服务器开服很卡怎么办?服务器开服卡顿如何解决

    服务器开服瞬间出现严重卡顿,核心症结往往不在于服务器硬件性能不足,而在于突发流量超出带宽负载上限、数据库读写遭遇死锁瓶颈以及游戏逻辑层的资源竞争,解决这一问题的关键在于实施流量削峰、数据库架构优化以及代码级的并发控制,单纯堆砌硬件无法从根本上解决问题, 带宽资源瞬时过载与流量削峰策略服务器开服时,大量玩家在同一……

    2026年3月27日
    4800
  • 服务器控制机房管理制度有哪些?机房管理规范详解

    服务器控制机房是企业数据资产的核心物理载体,其管理制度的严密性直接决定了业务系统的连续性与数据的安全性,构建一套科学、规范、可执行的机房管理制度,核心在于建立“物理环境绝对安全、人员操作全程可控、应急响应迅速有效”的闭环体系,将人为风险与环境风险降至最低, 这不仅是IT运维的基本要求,更是企业合规运营的生命线……

    2026年3月13日
    9200
  • 服务器有几个存储空间插槽,服务器硬盘位怎么查看数量?

    服务器的存储空间插槽数量并非固定值,而是取决于服务器的物理架构、机架高度(U数)以及具体的应用场景设计,通常情况下,企业级机架式服务器的硬盘插槽数量在2个到24个之间,部分高密度存储服务器甚至可扩展至48个或更多, 要准确评估一台设备的扩展能力,必须结合机箱规格、硬盘尺寸(2.5英寸或3.5英寸)以及是否支持后……

    2026年2月24日
    10700
  • 服务器怎么使用yum,yum安装配置命令详解

    在Linux服务器运维体系中,Yum(Yellow dog Updater, Modified)作为RPM系发行版的核心包管理工具,其正确使用直接关系到服务器的稳定性与安全性,核心结论是:高效使用Yum不仅在于简单的安装命令,更在于掌握仓库配置、依赖解决、缓存管理以及特定场景下的故障排除,通过标准化操作流程,实……

    2026年3月22日
    6100
  • 服务器提示找不到数据库文件路径,数据库文件路径怎么解决?

    服务器提示找不到数据库文件路径,本质上是系统环境配置与实际存储状态不一致导致的连接中断,解决该问题的核心在于校准配置文件路径、核实文件权限以及排查服务运行状态,而非单纯依赖重启服务,这一故障往往预示着底层存储逻辑发生了变更或阻断,必须通过系统性的排查流程来精准定位并修复,以恢复业务的连续性,故障根源的精准定位面……

    2026年3月13日
    6700
  • 高级网络安全租赁怎么选?企业高防服务器租用哪家好

    2026年企业应对动态威胁与合规压力的最优解,是采用高级网络安全租赁,它以订阅制将顶尖安全能力转化为低门槛、弹性扩展的业务护城河,为何高级网络安全租赁成为2026年刚需采购逻辑的根本性重构传统“买硬件、堆盒子”的重资产模式,在云原生与AI双重冲击下已显疲态,根据Gartner 2026年最新预测,超过70%的企……

    2026年4月25日
    1200
  • 服务器进程关闭全攻略,安全操作步骤详解 | 如何关闭服务器进程?服务器优化技巧

    服务器的进程可以关闭是的,服务器上运行的特定进程在满足必要条件下是可以且有时必须被关闭的, 正确识别并安全终止不必要的、失控的、或存在安全风险的进程,是服务器运维管理的关键操作,有助于释放系统资源、提升性能、维护系统稳定性和安全性,关闭进程必须遵循严谨的流程和风险评估,避免导致服务中断或系统崩溃, 为什么需要关……

    2026年2月11日
    8130

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注