0

0

OpenSSH多域名证书配置及身份验证链管理

冷漠man

冷漠man

发布时间:2026-03-14 18:59:03

|

354人浏览过

|

来源于php中文网

原创

OpenSSH通过CA机制实现多主机统一信任,替代传统多域名证书:用ssh-keygen生成CA密钥,签发用户/主机证书,服务器配置TrustedUserCAKeys或HostCertificate,客户端自动验证证书链。

openssh多域名证书配置及身份验证链管理

OpenSSH 不支持传统意义上的“多域名证书”或 X.509 证书链式身份验证(那是 TLS/SSL 的机制),它使用的是基于公钥的认证体系,核心是 ssh-keygen 生成的密钥对和 authorized_keys 文件。所谓“多域名”或“身份验证链”,实际是指:如何让一个 SSH 密钥对安全、灵活地用于多个主机(不同域名/IP)、多个用户身份,并支持可信委托(如 CA 签发的用户/主机密钥)。下面从实用角度讲清关键配置与管理逻辑。

用 SSH CA 实现多主机统一信任(替代“多域名证书”)

OpenSSH 自 6.8 起支持证书颁发机构(CA)模式,这是最接近“证书链”的方案——你无需在每台服务器上手动追加公钥,而是由一台可信 CA 签发用户/主机证书,服务器只需信任该 CA 公钥即可验证所有签名证书。

  • 生成 CA 密钥:ssh-keygen -t rsa -b 4096 -f ca_key(私钥保密,公钥 ca_key.pub 分发给所有服务器)
  • 为用户签发证书:ssh-keygen -s ca_key -I user@example.com -n user1 -V +52w id_rsa.pub-n 指定允许登录的用户名,-V 设有效期)
  • 服务器端配置:/etc/ssh/sshd_config 中添加 TrustedUserCAKeys /etc/ssh/ca_key.pub,然后重启 sshd
  • 客户端使用时,直接用签发后的私钥连接,服务端自动校验证书链(CA 公钥 → 用户证书 → 用户私钥)

一个密钥对安全复用多个域名/主机的方法

不依赖 CA 时,“多域名”本质是让同一组密钥在不同主机上生效。关键是控制密钥分发范围与权限粒度:

AssemblyAI
AssemblyAI

转录和理解语音的AI模型

下载
  • 把公钥(id_rsa.pub)内容追加到各目标主机的 ~/.ssh/authorized_keys,支持多行、多主机
  • command=from=no-port-forwarding 等选项限制单个公钥的行为(例如:某公钥仅允许从特定 IP 连接,或只执行备份命令)
  • 避免使用空密码私钥;推荐配合 ssh-agentgpg-agent 管理解密口令,提升多环境使用体验
  • 可为不同用途生成独立密钥对(如 id_rsa_workid_rsa_personal),再通过 ~/.ssh/config 绑定域名与密钥:
    Host work.example.com<br>  IdentityFile ~/.ssh/id_rsa_work

主机密钥信任链:如何安全验证目标服务器身份

客户端首次连接时保存的 ~/.ssh/known_hosts 就是你的“主机身份信任链”。要实现跨域名的可信验证(比如 web1.example.comweb2.example.com 都由同一 CA 签发主机证书):

  • 用 CA 签发主机证书:ssh-keygen -s ca_key -I host/web1.example.com -h -n web1.example.com -V +52w /etc/ssh/ssh_host_rsa_key.pub
  • 服务器配置中启用:HostCertificate /etc/ssh/ssh_host_rsa_key-cert.pub
  • 客户端设置 ~/.ssh/config
    Host *.example.com<br>  StrictHostKeyChecking yes<br>  UserKnownHostsFile /dev/null<br>  GlobalKnownHostsFile /etc/ssh/ssh_known_hosts
    ,并把 CA 公钥放入 /etc/ssh/ssh_known_hosts(以 @cert-authority 开头)
  • 这样,只要主机证书由该 CA 签发且域名匹配,客户端就自动信任,无需手动确认指纹

清理与轮换:避免身份链失效或泄露

长期运行中,密钥过期、人员变动、服务器迁移都会导致信任链断裂。必须建立运维闭环:

  • 用户证书过期后,服务端会拒绝登录,需重新签发;建议用短有效期(如 90 天)+ 自动化脚本续期
  • 撤销已泄露或离职用户的访问权:修改 CA 的 revoked_keys 文件(需 OpenSSH ≥ 7.5),并在 sshd_config 中配置 RevokedKeys /etc/ssh/revoked_keys
  • 主机密钥轮换时,先部署新密钥+证书,再更新客户端的全局 known_hosts,最后停用旧密钥,避免中断
  • 定期审计 authorized_keys 内容、CA 签发记录和证书有效期(可用 ssh-keygen -L -f cert.pub 查看证书详情)

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1109

2024.03.01

SSL检测工具介绍
SSL检测工具介绍

SSL检测工具有SSL Labs、SSL Check、SSL Server Test、SSLMate、SSL/TLS Analyzer等。详细介绍:1、SSL Labs是一个由Qualys提供的在线SSL检测工具,可以评估服务器证书的部署情况、加密套件、协议支持等方面的安全性,它提供了一个详细的报告,包括证书的颁发者、有效期、安全性配置等;2、SSL Check等等。

355

2023.10.20

PHP 命令行脚本与自动化任务开发
PHP 命令行脚本与自动化任务开发

本专题系统讲解 PHP 在命令行环境(CLI)下的开发与应用,内容涵盖 PHP CLI 基础、参数解析、文件与目录操作、日志输出、异常处理,以及与 Linux 定时任务(Cron)的结合使用。通过实战示例,帮助开发者掌握使用 PHP 构建 自动化脚本、批处理工具与后台任务程序 的能力。

67

2025.12.13

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

88

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

272

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

59

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

99

2026.03.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号