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 / 问题 / 532985
Accepted
Esoteric Eric
Esoteric Eric
Asked: 2019-07-31 10:19:47 +0800 CST2019-07-31 10:19:47 +0800 CST 2019-07-31 10:19:47 +0800 CST

只加载私钥时 ssh-copy-id 如何获取公钥?

  • 772

当我为用户加载了私钥时,我可以运行ssh-copy-id user@remotehostname并提示输入密码。当我输入正确的密码后,我现在可以使用密钥登录了。我以前总是将此命令-i <path to public key>作为参数运行,但现在意识到我不需要公钥的路径。

当我以 user@hostname 身份登录时,我会搜索 .ssh/authorized_keys 文件,并查看与我的私钥匹配的公钥,这让我感到困惑——我从未提供过公钥。

当我运行命令时,ssh-copy-id 如何知道哪个公钥与我在本地加载的私钥匹配?当我不提供授权密钥文件时,它怎么知道要添加什么?

我希望我很清楚——我一直在跑步ssh-copy-id -i <public key>,这对我来说很有意义——它登录并将公钥复制到授权的密钥文件中。但是如果我不提供公钥(即我ssh-add <private key>在运行 ssh-copy-id 之前运行),只要我加载了私钥,它仍然可以工作,而且我不明白它是如何获取公钥的。

编辑:澄清一下,我没有保留默认的 id*.pub 命名约定。因此,我在手册页中看到的关于搜索 id*.pub 的逻辑似乎并不适用。事实上,我可以创建一个名为 randompair 的密钥对,加载 randompair,将 rendompair.pub 重命名为 newname.pub,运行 ssh-copy-id,它仍然会加载正确的公钥。

查看 bash 脚本本身让我对它是如何实现这一点感到有些困惑。

ssh key-authentication
  • 2 2 个回答
  • 1899 Views

2 个回答

  • Voted
  1. Best Answer
    Gilles 'SO- stop being evil'
    2019-07-31T10:56:20+08:002019-07-31T10:56:20+08:00

    这在最近系统的手册页中有很好的记录。请注意,脚本有几个不同的版本;Arch Linux和RHEL/CentOS似乎与Debian/Ubuntu具有相同的版本,但FreeBSD的选项略有不同。

    默认情况下,ssh-copy-id调用ssh-add -L列出您在 SSH 代理中注册的密钥。ssh-add -L输出您在代理中拥有私钥的公钥列表。您可能想知道代理如何做到这一点,因为您也没有向它传递公钥。答案是始终可以从私钥重建公钥(对于 SSH 支持的所有密码系统都是如此,但大多数不支持)。然而,这仅适用于密钥的“数学”部分。公钥文件还可以包含一个注释(可以用 设置ssh-keygen -C),代理不会加载这个注释,所以如果你使用ssh-copy-id它并且它通过代理获取一个密钥,远程主机不会有这个注释authorized_keys。

    如果没有正在运行的代理或没有任何密钥,则最近的 Linuxssh-copy-id查找(直接来自手册页)

    匹配的最新文件: ~/.ssh/id*.pub, (不包括匹配的文件~/.ssh/*-cert.pub)因此,如果您创建的密钥不是您要ssh-copy-id使用的密钥,只需touch(1)在首选密钥的.pub文件上使用以将其恢复为最新的。

    旧版本的脚本和非 Linux 版本没有这种最近的文件行为。据我记得,即使是旧版本也没有探测代理,默认情况下只是读取默认路径~/.ssh/id_rsa.pub。

    • 5
  2. mico
    2019-07-31T10:56:44+08:002019-07-31T10:56:44+08:00

    ssh-copy-id 使用 [1] ssh-add -L 命令,它允许 [2]

    您可以查看 ssh-agent 当前维护的身份的公钥。

    所以,如果没有 -i 提供,它可以通过这种方式找到它。

    [1] https://linux.die.net/man/1/ssh-copy-id

    [2]如何检查哪些 SSH 密钥当前处于“活动状态”?

    • 0

相关问题

  • 为什么 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