AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 550599
Accepted
iBug
iBug
Asked: 2019-11-06 21:26:02 +0800 CST2019-11-06 21:26:02 +0800 CST 2019-11-06 21:26:02 +0800 CST

SSH 用户 CA:使用选定的主机而不是所有主机签署用户证书?

  • 772

我有许多服务器共享一个共同的TrustedUserCAKeys. 我想签署一个用户证书,以便它授予对特定服务器而不是所有服务器的一些访问权限。

例如,以下命令会生成一个证书,该证书可用于在所有服务器上以 root 身份登录:

ssh-keygen -s ca -I example -n root id_rsa.pub

我尝试了以下命令,但它生成的证书......没用。

ssh-keygen -s ca -I example -n root@server1 id_rsa.pub

我打算生成一个证书,该证书只能在 server1 上以 root 身份登录,而不能在任何其他服务器上以 root 身份登录。我已确定这server1是该服务器上的 FQDN(或 的完整内容/etc/hostname)。sshd_config有没有办法在不触及任何主机的情况下实现这一目标?

ssh
  • 2 2 个回答
  • 1388 Views

2 个回答

  • Voted
  1. Best Answer
    PKapp
    2019-11-07T12:34:43+08:002019-11-07T12:34:43+08:00

    在不更改sshd_config文件的情况下,答案通常是否定的。实现这一点的机制是设置一个AuthorizedPrincipalsFile(或AuthorizedPrincipalsCommand)。如果在 中没有此指令sshd_config,则默认行为是身份验证尝试的用户名必须逐字列出,作为嵌入在证书中的主体之一。这就是为什么 'root' 可以工作,而 'root@server1' 不行。

    为了使使用“root@server1”的证书工作(不添加条目/root/.ssh/authorized_keys),您需要AuthorizedPrincipalsFile为 root 用户配置一个(后来的 OpenSSH 版本允许在Match块内使用此指令),并列出“root@server1”,并在其他服务器上做类似的事情。您还可以扩展它以允许适用于服务器组的证书,例如“root@dev”甚至“root@*”,只要每个适当的风格都列为AuthorizedPrincipalsFile.

    另一种实现方式是使用和 选项在.ssh/authorized_keys文件中显式列出 CA 密钥和允许的主体。这些在Authorized_Keys 文件格式的手册页描述中有所介绍。cert-authorityprincipals=sshd

    • 2
  2. Aakash Yadav
    2020-04-18T08:51:17+08:002020-04-18T08:51:17+08:00

    问题是当您颁发 ssh 证书时,如果您直接root 输入,Principals您将授予对所有信任您 CA 的服务器的访问权限。

    为避免这种情况,切勿使用username. 而是创建访问策略。一个典型的场景是有些人需要访问测试服务器,有些人需要访问数据库服务器,有些人需要访问所有服务器。所以我创造了多个原则

    • project-dev - 访问开发/测试服务器
    • project-databases- 访问数据库服务器
    • project-super- 访问所有服务器

    AuthorizedPrincipalsFile /etc/ssh/auth_principals/%u为了实现这个添加sshd_config文件。

    因此,当有人尝试使用root用户名登录服务器时,它会检查文件/etc/ssh/auth_principals/root(notice%u代表用户)。

    因此,如果用户证书具有此文件中列出的原则,用户将被授予访问权限。

    此方案的授权原则文件将是

    • 开发服务器 -project-dev\nproject-super
    • 数据库服务器 -project-dev\nproject-super
    • 生产服务器 -project-super

    因此,根据您的需求制定策略。

    root注意:如果您仍然使用in颁发证书,Principles它仍然可以工作。所以避免这种情况。

    我写了一篇博客来设置完整的 ssh 证书基础设施:

    https://medium.com/better-programming/how-to-use-ssh-certificates-for-scalable-secure-and-more-transparent-server-access-720a87af6617

    • 1

相关问题

  • 为什么 ssh 实用程序被视为 pty?

  • Auto-SSH 手动工作,但不在后台工作

  • 远程运行 X 应用程序,在远程主机上运行 GUI [关闭]

  • rsync 端口 22 和 873 使用

  • SCP突然中止:管道损坏,消息验证码不正确

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve