魔咱奈你 2023-02-10 19:00 采纳率: 100%
浏览 16
已结题

使用xshell在ssh端口转发穿越多重跳板机的原理及配置?

现想实现ssh从a(跳板机)->b(跳板机)->c(target),工具:xshell

  1. 在session_a(xshell中的会话框destination为a)中点击配置localhost与b的端口映射配置后(port1),再开一个session_127.0.0.1_port1,dest为127.0.0.1,但是无法连接到b;
  2. 如果在session_a中点击配置与c的端口映射(port2), 在命令行中手动登录ssh b 后,再开一个session_127.0.0.1_port2,就可以连接到c。

问题:既然与b的端口转发用不了,为什么2的操作仍然能实现?这是什么原理?

  • 写回答

2条回答 默认 最新

  • 社区专家-Monster-XH 2023-02-10 19:03
    关注

    这种方式是通过SSH隧道(SSH Tunnel)实现的。

    在操作 2 中,你首先通过 session_a 与 b 建立了一条连接,并将 b 作为一个中间点,再通过 b 与 c 建立了另一条连接。这样,你就在本地构建了一个隧道,绕过了 a 到 b 的直接连接。

    为什么操作 1 不可行?

    在操作 1 中,你将 session_a 中的端口映射配置为 b,但并未实际连接 b。因此,在第二个 session_127.0.0.1_port1 中,连接到 127.0.0.1 的端口,不会有任何数据被转发到 b。

    总而言之,通过 SSH 隧道实现 a -> b -> c 的连接,需要首先通过一个会话(session_a)与 b 建立连接,再通过 b 与 c 建立另一条连接。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月28日
  • 已采纳回答 2月20日
  • 创建了问题 2月10日

悬赏问题

  • ¥15 在codeblocks里主函数运行到打印生成的链表就结束了 没有再往下是为什么呢
  • ¥15 宇视vms-B200-A16@R启动不了,如下图所示,在软件工具搜不到,如何解决?(操作系统-linux)
  • ¥500 寻找一名电子工程师完成pcb主板设计(拒绝AI生成式答案)
  • ¥15 关于#mysql#的问题:UNION ALL(相关搜索:sql语句)
  • ¥15 matlab二位可视化能否针对不同数值范围分开分级?
  • ¥15 已经创建了模拟器但是不能用来运行app 怎么办😭自己搞两天了
  • ¥15 关于#极限编程#的问题,请各位专家解答!
  • ¥20 win11账户锁定时间设为0无法登录
  • ¥45 C#学生成绩管理系统
  • ¥30 matlab appdesigner私有函数嵌套整合