服务器怎么创建秘钥对?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
AIoT有哪些研究方向?AIoT研究方向前景如何
下一篇 2026年3月17日 14:43

相关推荐

  • 防火墙在Web安全中扮演什么角色?如何提升其防护效能?

    防火墙作为网络安全的第一道防线,其Web安全防护能力直接关系到企业数据资产和业务连续性,本文将深入解析防火墙在Web安全中的核心作用、关键技术及实施策略,帮助您构建专业可靠的防御体系, 防火墙Web安全的核心价值:从边界守卫到深度防御传统防火墙主要基于IP和端口进行访问控制,而现代Web应用防火墙(WAF)已演……

    2026年2月4日
    11000
  • 服务器有没有断电保护,服务器断电保护措施有哪些?

    服务器作为数据存储与计算的核心,其供电稳定性直接关系到业务连续性,针对 {服务器有没有断电保护} 这一关键问题,结论是肯定的:现代服务器具备多层次、立体化的断电保护机制,但这并不意味着服务器可以无限期在断电后运行,其保护逻辑是从硬件冗余到外部供电,再到软件层面的自动响应,旨在确保数据不丢失、硬件不损坏,并争取宝……

    2026年2月22日
    12100
  • 服务器怎么存储图片,图片存储在服务器哪个目录好

    服务器存储图片的核心策略在于构建高效的文件系统与数据库索引机制,即通过“物理存储+逻辑索引”的双层架构,实现图片的高可用存取,最优方案并非单纯将图片存入数据库,而是将图片以文件形式存储在专用服务器或对象存储中,数据库仅存储文件的引用路径,这种架构既保证了数据的安全性,又维持了系统的读写性能,是当前互联网应用的主……

    2026年3月18日
    8500
  • 服务器开发设计与实现怎么做?服务器开发流程详解

    高性能服务器架构的核心在于高并发处理能力与高可用性保障,其本质是通过合理的资源调度与冗余设计,在有限的硬件成本下实现业务吞吐量的最大化,服务器开发设计与实现的过程,实际上是对计算资源、网络I/O以及存储系统的精细化编排,旨在解决C10K乃至C10M问题,确保系统在流量洪峰面前依然能够保持稳定响应,优秀的架构设计……

    2026年4月8日
    5700
  • 个人舆情监测软件哪个好用?免费舆情监控系统推荐

    个人用户首选基于云端的轻量级舆情监测工具,如识微商情个人版、清博指数或百度指数,它们以低成本、低门槛和可视化数据为核心优势,足以满足个人自媒体、自由职业者及小微创业者的基础需求,对于个人而言,传统的企业级舆情系统往往因为高昂的授权费和复杂的操作逻辑而显得“水土不服”,随着大数据技术的下沉,市场上涌现出了一批专为……

    2026年6月12日
    1400
  • 服务器有万兆网口吗,服务器万兆网卡和千兆有什么区别

    在现代数据中心与企业级IT架构中,网络带宽已成为决定业务性能的关键瓶颈,针对服务器有万兆网口吗这一核心问题,答案是肯定的:绝大多数现代中高端服务器,甚至部分入门级塔式服务器,均已标配或支持万兆(10GbE)网络接口,万兆网口不再是昂贵的选配,而是高性能计算、虚拟化、大数据及AI场景下的标准配置,随着数据量的爆发……

    2026年2月21日
    15800
  • 服务器机架多少U?42U标准机柜尺寸详解

    服务器机架是现代数据中心、网络机房乃至企业IT基础设施的物理骨架,承载着服务器、网络设备、存储系统、配电单元(PDU)等关键设备,其规格的选择直接影响着空间利用率、散热效率、设备部署灵活性、维护便利性以及整体系统的稳定性和可扩展性,理解并精准选择机架规格是构建高效、可靠IT环境的基础,核心规格解析:机架选择的五……

    2026年2月13日
    13100
  • 个人云服务器必须绑定域名吗?云服务器域名怎么备案

    个人用的云服务器完全不需要强制绑定域名,直接使用IP地址访问即可满足基础需求,但绑定域名能提升安全性、易用性及专业形象,具体取决于你的使用场景,很多新手在入手第一台云服务器时,往往会被各种复杂的网络概念绕晕,服务器和域名的关系,就像房子和门牌号,IP地址是服务器的物理定位,而域名则是为了方便记忆而起的别名,对于……

    2026年5月27日
    3300
  • 个人开发网站云服务器怎么选,个人建站云服务器推荐

    个人开发网站云服务器首选轻量应用服务器,因其性价比高、配置透明且自带建站环境,适合90%以上的个人开发者需求,为什么个人开发者应避开传统云厂商的复杂套餐很多新手在选购云服务器时,容易陷入“参数越高越好”的误区,直接去阿里云、腾讯云等大厂购买标准型ECS或CVM实例,这种做法往往导致预算超支且配置闲置,业内专家指……

    2026年5月30日
    2200
  • 个人服务器如何有效防DoS攻击?DoS攻击原理与防护方案

    个人服务器防DDoS攻击的核心在于“前置清洗”与“本地加固”相结合,对于绝大多数个人用户而言,接入高防CDN或云厂商提供的免费基础防护服务是性价比最高且最有效的解决方案,单纯依赖服务器本地配置无法抵御大规模流量攻击,对于拥有独立服务器(VPS或物理机)的个人开发者、站长或极客来说,DDoS(分布式拒绝服务)攻击……

    2026年5月28日
    2100

发表回复

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