Join GitHub today

GitHub is home to over 28 million developers working together to host and review code, manage projects, and build software together.

Sign up

利用 Python 的 Socket 端口转发,用于远程维护

简介

  • 利用 Python 的 Socket 端口转发,用于远程维护
  • 如果连接不到远程,会 sleep 36s,最多尝试 200 次(即两小时)

用法

  • ./rtcp.py stream1 stream2
  • stream 为:l:port 或 c:host:port
  • l:port 表示监听指定的本地端口
  • c:host:port 表示监听远程指定的端口

使用场景

A 服务器在内网,公网无法直接访问这台服务器,但是 A 服务器可以联网访问公网的 B 服务器(假设 IP 为 222.2.2.2)

我们也可以访问公网的 B 服务器。我们的目标是访问 A 服务器的 22 端口。那么可以这样:

  • 在 B 服务器上运行:./rtcp.py l:10001 l:10002

    • 表示在本地监听了 10001 与 10002 两个端口,这样,这两个端口就可以互相传输数据了
  • 在 A 服务器上运行:./rtcp.py c:localhost:22 c:222.2.2.2:10001

    • 表示连接本地的 22 端口与 B 服务器的 10001 端口,这两个端口也可以互相传输数据了
  • 然后我们就可以这样来访问 A 服务器的 22 端口了:ssh -p 10002 222.2.2.2

    • 原理很简单,这个命令执行后,B 服务器的 10002 端口接收到的任何数据都会传给 10001 端口
    • 此时,A 服务器是连接了 B 服务器的 10001 端口的,数据就会传给 A 服务器,最终进入 A 服务器的 22 端口
  • watercloud
  • zd
  • kun
  • Knownsec R&D Team