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
    • 最新
    • 标签
主页 / server / 问题 / 1064421
Accepted
Bemipefe
Bemipefe
Asked: 2021-05-23 09:39:20 +0800 CST2021-05-23 09:39:20 +0800 CST 2021-05-23 09:39:20 +0800 CST

ssh 端口转发,在远程和目标之间具有永久连接

  • 772

我知道您可以使用 ssh 将本地或远程端口转发到另一个目的地和端口。例如,假设我有这个命令:

ssh -L *:8443:10.0.0.1:443 [email protected]

因此,这允许在发出命令的机器上打开一个监听套接字(假设它的 ip 是10.0.0.3)在 port 上8443。当一些客户端连接到数据包时10.0.0.3:8443,数据包流通过它们之间建立的 ssh 通道10.0.0.3,10.0.0.2然后 ssh 服务器10.0.0.2将数据包转发到目的地,在这种情况下为 10.0.0.1:443。

我想知道服务器是否10.0.0.2可以建立永久连接,10.0.0.1:443以便连接10.0.0.2:xxxxx -> 10.0.0.1:443打开一次并且永远不会断开。来自连接到的客户端的所有流量10.0.0.3:8443都应使用此永久通道。

所以基本上我不希望在建立新客户端连接到10.0.0.3:8443新通道时出现这种10.0.0.2:xxxxx -> 10.0.0.1:443情况。这可以防止我重用同一个会话并使另一个客户端在第一个客户端之后发送的请求无效。

ssh port-forwarding ssh-tunnel socket
  • 1 1 个回答
  • 229 Views

1 个回答

  • Voted
  1. Best Answer
    Steffen Ullrich
    2021-05-23T10:24:21+08:002021-05-23T10:24:21+08:00

    SSH 无法做到这一点。无论如何,这种通用方法一开始就不是一个好主意。

    TCP 是字节流而不是消息协议。这意味着如果多个客户端并行发送消息,则消息可能会混淆。生成的数据可能从客户端 A 的 msgA 的开头开始,从客户端 B 的 msgB 的部分继续,从 msgA 的另一部分继续,等等。

    因此,实际上需要一个混合器来代替通用方法,该混合器可以理解所说的特定应用程序协议,并确保保留合并数据流中的消息语法,无论客户端如何发送消息。

    请注意,这与 UDP 不同,因为 UDP 是基于消息的。但是您的用例似乎是 TCP。

    • 1

相关问题

  • 如何最好地设置 ssh 隧道以访问远程网络 (Linux)

  • SSH 和重定向

  • 通过 SSH 会话使用 NET USER 命令拒绝访问

  • SSH 服务器零日漏洞利用 - 保护自己的建议

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve