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 / 问题 / 782694
Accepted
ncoghlan
ncoghlan
Asked: 2024-08-29 12:24:01 +0800 CST2024-08-29 12:24:01 +0800 CST 2024-08-29 12:24:01 +0800 CST

使用 systemd 套接字激活时,WSL 上的第一个 ssh-agent 请求失败

  • 772

在 WSL2 上运行 Fedora 时,我发现套接字激活ssh-agent不能正常工作:触发实际服务启动的第一个请求失败。这可能是git fetch或git pull请求,也可能是ssh-add调用。这显示为客户端调用的长时间超时,而不是立即失败。

由于 systemd 配置包含和ssh-agent.socket , ssh-agent.service因此尝试直接禁用ssh-agent.socket和启用不起作用ssh-agent.service,因为它只是重新打开套接字激活,而不是将服务配置为自动启动:

~$ systemctl --user is-enabled ssh-agent.socket
enabled
~$ systemctl --user is-enabled ssh-agent.service
indirect
~$ systemctl --user enable ssh-agent.service
~$ systemctl --user is-enabled ssh-agent.service
indirect
~$ systemctl --user disable ssh-agent.socket
Removed "/home/acoghlan/.config/systemd/user/sockets.target.wants/ssh-agent.socket".
~$ systemctl --user enable ssh-agent.service
Created symlink /home/acoghlan/.config/systemd/user/sockets.target.wants/ssh-agent.socket → /usr/lib/systemd/user/ssh-agent.socket.
windows-subsystem-for-linux
  • 2 2 个回答
  • 17 Views

2 个回答

  • Voted
  1. u1686_grawity
    2024-08-29T14:50:38+08:002024-08-29T14:50:38+08:00

    OpenSSH ssh-agent 不支持套接字激活——它不知道必须从父级接收套接字交接,而是始终建立自己的套接字。

    因此,您的第一个请求会被困在 systemd 建立的套接字队列中(ssh-agent 刚刚取消链接并用自己的套接字替换),而第二个请求现在会通过恰好具有相同名称的不同套接字。

    这不是时间问题;套接字激活本质上是“即时”的(当与知道如何接受它的程序一起使用时),特别是因为初始请求在套接字队列中停留的时间与程序在拾取之前需要初始化的时间一样长——这实际上是当程序不知道如何接受它时导致此问题的原因。(所以它与“需要时间来整理自己”完全相反。)

    • 1
  2. Best Answer
    ncoghlan
    2024-08-29T12:24:01+08:002024-08-29T12:24:01+08:00

    我不想调整 systemd 配置(这不仅可能最终成为特定于发行版的并且可能会随着时间的推移而改变,而且还会影响我没有启动交互式 shell 的情况),而是想要添加一些可以.bash_profile确保实际ssh-agent服务始终在交互式会话中运行,而不仅仅是监听套接字。

    ssh-add -l(列出已加载的密钥指纹)似乎是一个很好的触发命令(因为ssh-add如果我打算使用 SSH,它会提醒我运行),用于timeout检测故障(因为ssh-add -l如果代理正常工作,通常应该是接近即时的)。

    .bash_profile这给出了以下解决方法(我将其添加到我的主目录的末尾):

    export SSH_AUTH_SOCK="$XDG_RUNTIME_DIR/ssh-agent.socket"
    
    timeout 1 ssh-add -l # Ensure ssh-agent service is actually running
    if [ $? -gt 1 ]; then
        echo "Attempt to contact ssh-agent failed, retrying..."
        sleep 1 # Give socket activation time to sort itself out
        timeout 1 ssh-add -l  # Keep timeout in case agent really is down
    fi
    

    (ssh-add -l如果没有加载任何密钥,则报告退出代码 1,但如果连接尝试失败,则报告退出代码 2。由于timeout失败代码均为 124 或更高,因此[ $? -gt 1 ]在尝试激活套接字时检查会检测到任何失败。仅检查timeout错误代码通常仍会在实例重新启动后立即失败,并显示消息“连接到代理时出错:没有此文件或目录”)

    WSL2 实例重启后新终端会话的示例输出:

    Error connecting to agent: No such file or directory
    Attempt to contact ssh-agent failed, retrying...
    The agent has no identities.
    ~$ _
    
    • 0

相关问题

  • SSH linux子系统windows 10

  • Bash For循环不起作用

  • SSH进入同一网络上的两台不同机器[关闭]

  • 在 Bash 中绑定 ALT-F4 以退出的方法(Windows 上的 Ubuntu 上的 Bash)

  • 适用于 Linux 的 Windows 子系统上的 OpenZFS

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