gpt4 book ai didi

ssh - 为什么即使端点出现故障,转发的 SSH 端口似乎仍然打开?

转载 作者:行者123 更新时间:2023-12-02 03:05:54 24 4
gpt4 key购买 nike

我将 SSH 端口转发隧道安装到远程服务器 RemoteServerSSH55555 端口转发到不存在的设备(这是我尝试测试的内容)。

$ hostname
MyMachine

设置转发隧道

$ ssh -q -N -p 22 -vvv \
-i ~/.ssh/MyKey \
-o Compression=yes \
-o ServerAliveInterval=3 \
-o serverAliveCountMax=3 \
-L *:55555:RemoteDownItem:9100 user@RemoteServerSSH

测试隧道

当我直接telnet 设备时,我得到了正确的行为(未连接)。然而,当我尝试通过隧道访问它时,telnet 说它已连接:

$ telnet RemoteDownItem 9100   # Not Connected = OK
$ telnet MyMachine 55555 # Connected! Why? should be same as above

当我测量 telnet 时间连接时,它是瞬时的(1ms!)。回答我的是 SSH 客户端,它没有穿过 ssh 隧道!为什么?

详细

...
debug1: Local connections to *:55555 forwarded to remote address 10.220.9.183:9100
debug3: channel_setup_fwd_listener: type 2 wildcard 1 addr NULL
debug1: Local forwarding listening on 0.0.0.0 port 55555.
debug2: fd 4 setting O_NONBLOCK
debug3: fd 4 is O_NONBLOCK
debug1: channel 0: new [port listener]
debug3: sock_set_v6only: set socket 5 IPV6_V6ONLY
debug1: Local forwarding listening on :: port 55555.
debug2: fd 5 setting O_NONBLOCK
debug3: fd 5 is O_NONBLOCK
debug1: channel 1: new [port listener]
debug2: fd 3 setting TCP_NODELAY
debug3: packet_set_tos: set IP_TOS 0x10
debug1: Requesting no-more-sessions@openssh.com
debug1: Entering interactive session.


debug1: Connection to port 55555 forwarding to 10.220.9.183 port 9100 requested.
debug2: fd 6 setting TCP_NODELAY
debug2: fd 6 setting O_NONBLOCK debug3: fd 6 is O_NONBLOCK
debug1: channel 2: new [direct-tcpip]

问题

是否有 SSH 参数将 telnet 连接直接转发到端点?

项目相关问题

Telnet connect to non-existing adress

最佳答案

考虑隧道的工作原理。当您运行类似 ssh -L *:55555:RemoteDownItem:9100 user@host 的命令时,端口转发的处理方式如下:

  1. 本地 ssh 实例绑定(bind)到 TCP 端口 55555 并监听连接。
  2. “发起者”连接到本地系统上的端口 55555。本地 ssh 实例接受 TCP 连接。
  3. 本地 ssh 实例发送一个 "direct-tcpip" request通过 SSH 连接到远程 ssh 服务器。
  4. 远程 ssh 服务器尝试连接到主机“RemoteDownItem”端口 9100

在第 4 步,如果 ssh 服务器能够连接到隧道的目标,则 ssh 客户端和服务器将各自通过 direct-tcpip channel 在发起方和目标之间中继数据。

或者,在第 4 步,服务器可能无法与目标建立 TCP 连接。或者服务器可能被配置为不允许转发请求。在任何一种情况下,它都会向客户端响应一个错误(或一条消息说 channel 已关闭)。

此时,本地 ssh 实例唯一能做的就是关闭与发起者的 TCP 连接。从发起者的角度来看,它成功连接到一个“服务器”(ssh 客户端),然后“服务器”几乎立即关闭了连接。

OpenSSH 软件不包含任何以更复杂的方式处理此问题的逻辑。以更复杂的方式处理它可能很困难。考虑:

  • 远程 SSH 服务器在尝试之前不知道它是否可以连接到“RemoteDownItem”端口 9100。所以 ssh 提前弄清楚端口转发不起作用是有问题的。

  • 即使一次尝试连接到目标失败,下一次尝试也可能成功。因此,仅仅因为一次尝试失败,ssh 就假设端口转发不起作用是有问题的。

  • 远程SSH服务器可以成功连接到目标,然后目标可以立即关闭TCP连接。所以 ssh 服务器、ssh 客户端和发起者无论如何都必须处理这种行为。

关于ssh - 为什么即使端点出现故障,转发的 SSH 端口似乎仍然打开?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42860110/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com