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
    • 最新
    • 标签
主页 / computer / 问题 / 1488097
Accepted
aircraft
aircraft
Asked: 2019-10-02 06:05:51 +0800 CST2019-10-02 06:05:51 +0800 CST 2019-10-02 06:05:51 +0800 CST

OpenSSH 是否支持多跳登录?

  • 772

Ansible 使用 OpenSSH 作为底层网络通信实现,但它是否支持多跳登录?

我的意思是,如果 Ansible 可以直接登录服务器,但它可以登录 server_a 然后从 server_a 登录 server_b 配置 server_b 吗?

ssh openssh
  • 2 2 个回答
  • 1952 Views

2 个回答

  • Voted
  1. Best Answer
    Martin Prikryl
    2019-10-02T06:12:27+08:002019-10-02T06:12:27+08:00

    我不知道 Ansible 如何使用 OpenSSH。


    但是 OpenSSH 本身支持“多跳登录”。

    从 OpenSSH 7.3 开始,您可以使用-J(跳转)开关,例如:

    ssh -J [email protected] [email protected]
    

    -J相当于ProxyJump指令:_

    ssh -o [email protected] [email protected]
    

    请注意,对于文件传输工具,例如scp和sftp,-J仅从 8.0 开始支持该开关。对于旧版本(但至少 7.3),使用ProxyJump. 请参阅如何从只能通过 SSH 连接到另一台主机的主机下载文件?

    另请注意,这些版本指的是 OpenSSH 的本地版本。OpenSSH 的远程版本不相关。


    正如@GordonDavisson 评论的那样,对于旧版本(但至少为 5.4),您可以使用ProxyCommand指令和-Wswitch:

    ssh -o ProxyCommand="ssh -W %h:%p [email protected]" [email protected]
    

    即使是旧版本,您也可以使用nccommand而不是-W:

    ssh -o ProxyCommand="ssh user2@%h nc host2.example.com 22" \
        -o HostKeyAlias=host2.example.com \
        host1.example.com
    

    Wikibooks 文章OpenSSH/Cookbook/Proxies 和 Jump Hosts中详细介绍了上述所有选项 。


    另一种选择是使用端口转发(-Lswitch)。但这涉及两个ssh例子。我不确定 Ansible 是否可行。

    • 9
  2. HoD
    2019-10-05T00:06:38+08:002019-10-05T00:06:38+08:00

    对于较旧的 Ansible 版本,您必须按照 Martin Prikryls 的回答中所述在通用 SSH 配置中执行此操作。新版本具有 Ansible 特定配置,如一般常见问题解答中所述

    如何配置跳转主机以访问我无法直接 访问的服务器?

    您可以在 ansible_ssh_common_args 库存变量中设置 ProxyCommand。连接到相关主机时,此变量中指定的任何参数都会添加到 sftp/scp/ssh 命令行。考虑以下库存组:

    [gatewayed] foo ansible_host=192.0.2.1 bar ansible_host=192.0.2.2

    您可以使用以下内容创建 group_vars/gatewayed.yml:

    ansible_ssh_common_args: '-o ProxyCommand="ssh -W %h:%p -q [email protected]"'

    当尝试连接到网关组中的任何主机时,Ansible 会将这些参数附加到命令行。(这些参数用于 ansible.cfg 中的任何 ssh_args,因此您无需在 ansible_ssh_common_args 中重复全局 ControlPersist 设置。)

    请注意, ssh -W 仅适用于 OpenSSH 5.4 或更高版本。对于旧版本,必须在堡垒主机上执行 nc %h:%p 或一些等效命令。

    对于早期版本的 Ansible,有必要在 ~/.ssh/config 中为一个或多个主机配置合适的 ProxyCommand,或者通过在 ansible.cfg 中设置 ssh_args 来全局配置。

    这样,您就有了一种非常 Ansible-esque 的方式,仅在需要时设置 SSH 堡垒主机,以及任何其他特殊的 SSH 设置(如密钥、用户等)。

    • 1

相关问题

  • 如何使用 GUI 远程访问 EC2 控制台

  • 需要 LDAP 身份验证 * 和 * ssh 身份验证

  • 加载密钥“ec256.pem”:尝试从私钥生成公钥时抛出无效格式

  • 为什么 chown 600 id_rsa 修复权限问题?

Sidebar

Stats

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

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    Windows 10 服务称为 AarSvc_70f961。它是什么,我该如何禁用它?

    • 2 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Marko Smith

    ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] 证书验证失败:无法获取本地颁发者证书 (_ssl.c:1056)

    • 4 个回答
  • Marko Smith

    我如何知道 Windows 安装在哪个驱动器上?

    • 6 个回答
  • Martin Hope
    Albin 支持结束后如何激活 WindowsXP? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 “HTTPS Everywhere”仍然相关吗? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch Windows 10 删除大量小文件的速度非常慢。有什么办法可以加快速度吗? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Ctrl+C 和 Ctrl+V 是如何工作的? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve