如何快速入睡

密钥登录的核心优势

  1. 安全性
    • 私钥存储在本地,公钥在服务器,破解难度远高于密码。
    • 支持禁用密码登录,彻底杜绝密码爆破风险。
  2. 便捷性

    免去每次输入密码的麻烦,适合自动化脚本(如CI/CD)。

  3. 符合安全规范

    金融、云计算等场景强制要求密钥登录(如AWS/Aliyun)。


密钥登录配置步骤

步骤1:本地生成密钥对(在客户端操作)

ssh-keygen -t ed25519 -C "your_email@example.com"  # 推荐ed25519算法
  • 操作提示
    • 按回车使用默认存储路径(~/.ssh/id_ed25519)。
    • 设置密钥密码(Key Passphrase)可增加二次保护(可选)。
  • 生成文件
    • 私钥:~/.ssh/id_ed25519(权限需为600)
    • 公钥:~/.ssh/id_ed25519.pub

⚠️ 关键权限设置
执行命令确保私钥安全:
chmod 600 ~/.ssh/id_ed25519

步骤2:上传公钥到服务器

ssh-copy-id -i ~/.ssh/id_ed25519.pub user@server_ip
  • 输入服务器密码后,公钥会自动写入 ~/.ssh/authorized_keys
  • 手动方案(若无ssh-copy-id):
    cat ~/.ssh/id_ed25519.pub | ssh user@server_ip "mkdir -p ~/.ssh && chmod 700 ~/.ssh && cat >> ~/.ssh/authorized_keys"

步骤3:服务器端配置(以OpenSSH为例)

  1. 编辑SSH配置文件:
    sudo nano /etc/ssh/sshd_config
  2. 修改以下参数:
    PubkeyAuthentication yes     # 启用密钥认证
    PasswordAuthentication no    # 禁用密码登录(测试后再启用!)
    AuthorizedKeysFile .ssh/authorized_keys
  3. 重启SSH服务:
    sudo systemctl restart sshd

步骤4:测试密钥登录

ssh -i ~/.ssh/id_ed25519 user@server_ip
  • 成功登录后,再禁用密码登录(避免配置错误被锁)。

安全加固与故障处理

必做权限检查

chmod 600 ~/.ssh/authorized_keys
  • 权限错误会导致登录失败(常见错误:Permission denied (publickey))。

禁用密码登录(增强安全)

确认密钥登录成功后,在sshd_config中设置:

PasswordAuthentication no
ChallengeResponseAuthentication no
UsePAM no

故障排查

  • 登录失败
    1. 检查客户端私钥路径:ssh -i /path/to/private_key user@ip
    2. 查看服务器日志:sudo tail -f /var/log/auth.log
    3. 临时启用密码登录:sudo systemctl restart sshd
  • 备份密钥

    私钥丢失无法恢复!建议加密备份到安全位置。


高级场景

  • 多密钥管理
    在客户端~/.ssh/config中配置:

    Host myserver
      HostName server_ip
      User user
      IdentityFile ~/.ssh/custom_key

    直接使用 ssh myserver 登录。

  • 跨平台使用
    • Windows:用PuTTYgen导入私钥,或WSL直接使用ssh-keygen
    • macOS/Linux:原生支持OpenSSH。

密钥登录是Linux服务器安全的基石,通过生成密钥对、上传公钥、配置服务端三步操作,即可实现免密安全登录。务必在测试后禁用密码登录,并定期审计密钥使用情况,企业环境建议结合证书颁发机构(CA)进一步强化信任链。

引用说明

  • OpenSSH官方文档:https://www.openssh.com/manual.html
  • Linux man 手册(命令:man ssh-keygen, man sshd_config
  • NIST安全指南(SP 800-53)关于密钥管理的要求

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/4949.html

(0)
酷番叔酷番叔
上一篇 2025年6月18日 22:55
下一篇 2025年6月18日 23:57

相关推荐

  • Linux如何查看已安装的所有软件?常用命令与方法详解

    在Linux系统中,软件安装方式因发行版和包管理器的不同而存在差异,查看已安装软件的方法也因此多样化,无论是基于Debian/Ubuntu的APT系列、RedHat/CentOS的YUM/DNF系列,还是Arch Linux的Pacman系列,亦或是第三方包管理器如Snap、Flatpak,均有对应的查询命令……

    2025年8月24日
    11700
  • Linux系统中如何正确删除.swp文件?

    在Linux系统中,.swp文件是vim或nano等文本编辑器在编辑文件时自动生成的临时备份文件,主要用于在编辑器异常退出(如直接关闭终端、系统断电)后恢复未保存的修改,正常情况下,当用户正常退出编辑器时,这些临时文件会被自动删除;但如果异常退出,.swp文件会残留下来,长期占用磁盘空间,甚至可能因文件名冲突导……

    2025年9月17日
    8700
  • 如何编译Linux内核模块?详细步骤与方法全解析

    Linux内核模块是可动态加载到内核空间的程序,用于扩展内核功能(如驱动、文件系统等)而无需重新编译整个内核,编译内核模块是Linux系统开发的基础技能,以下是详细步骤和注意事项,环境准备在开始编译前,需确保系统具备必要的工具和依赖:开发工具包:安装build-essential(包含gcc、make等)和li……

    2025年9月8日
    9500
  • Linux系统中,如何查看当前的主机名?有哪些方法?

    Linux主机名是网络中标识设备的唯一名称,用于区分不同服务器、终端或虚拟机,在系统管理、网络通信、日志记录等场景中至关重要,掌握查看主机名的方法是Linux运维的基础技能,本文将详细介绍多种查看方式,涵盖命令行工具、配置文件及图形界面,并分析不同方法的适用场景和输出差异,使用hostname命令查看主机名ho……

    2025年9月29日
    10400
  • linux7如何查看用户

    Linux7 中,可通过命令“cat /etc/passwd”查看

    2025年8月17日
    12400

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信