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
    • 最新
    • 标签
主页 / server / 问题 / 508406
Accepted
asciiphil
asciiphil
Asked: 2013-05-17 11:07:35 +0800 CST2013-05-17 11:07:35 +0800 CST 2013-05-17 11:07:35 +0800 CST

如何使用 Puppet 在系统重建期间维护 SSH 主机密钥?

  • 772

我有一些实验室环境,其中的计算机会定期重建,但需要保留相同的 ssh 主机密钥,以便连接到实验室计算机的人(通常来自他们自己的系统,不在我的管理下)不会得到“每次我们升级实验室系统的操作系统时都会出现主机密钥已更改”错误。

(这类似于问题Smoothest workflow to handle SSH host verification errors?但在这种情况下,我们已经决定在系统重建期间维护相同的密钥是我们最好的解决方案。)

现在,我有一个名为 Puppet 的模块ssh,其中包含以下子句:

file { "/etc/ssh/":
  owner   => 'root',
  group   => 'root',
  mode    => '0644',
  source  => "puppet:///modules/ssh/$fqdn",
  recurse => true,
  require => Package['openssh-server'],
  notify  => Service['sshd'],
}

在 puppet master 上,每个主机都有自己的目录,其中包含所有主机密钥文件(ssh_host_key、ssh_host_dsa_key、ssh_host_rsa_key等),如file资源定义所暗示的那样。我的问题是,这感觉就像混合了代码和数据(因为所有主机密钥都位于模块目录中),每次我添加一组新主机时,我都必须再次提交到 Puppet VCS。有没有更好的方法来管理这些事情?

ssh
  • 2 2 个回答
  • 3028 Views

2 个回答

  • Voted
  1. Best Answer
    Zoredache
    2013-05-17T11:54:20+08:002013-05-17T11:54:20+08:00

    我的问题是,这感觉就像混合了代码和数据(因为所有主机密钥都位于模块目录中),每次我添加一组新主机时,我都必须再次提交到 Puppet VCS。有没有更好的方法来管理这些事情?

    fileserver.conf如果您想将 puppet 文件与 SSH 配置/密钥分开,您可以调整并基本上共享另一个仅用于 ssh 配置的目录。

    fileserver.conf
    [sshconfig]
      path /srv/puppet/sshconfig/
      allow *
    

    使用上面的配置,您的清单可能如下所示,文件将从/srv/puppet/sshconfig/$fqdn/.

    file { "/etc/ssh/":
      source  => "puppet:///sshconfig/$fqdn",
      ...
    }
    
    • 4
  2. Valter Silva
    2013-05-17T11:41:36+08:002013-05-17T11:41:36+08:00

    我的建议是你创建一个module或一个script你上传你知道主机到external服务器的地方,然后你sort -u在这个文件中给出一个,不包括任何重复的条目,然后你上传这个文件到你所有的机器,当然要小心这也是新条目ssh_known_hosts。

    • 0

相关问题

  • 如何最好地设置 ssh 隧道以访问远程网络 (Linux)

  • SSH 和重定向

  • 通过 SSH 会话使用 NET USER 命令拒绝访问

  • SSH 服务器零日漏洞利用 - 保护自己的建议

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve