SSH 反向隧道:快速解决服务器网络限制

当服务器因网络限制无法使用 pip, git, curl 等工具时,可使用 SSH 反向隧道将其网络流量通过你的个人电脑进行代理。

原理

在有外网的个人电脑上运行一个代理服务,然后建立一条 SSH 反向隧道,将服务器的某个端口(如 1080)转发到个人电脑的代理端口。服务器上的程序通过访问自己的 127.0.0.1:1080 端口,流量就会经由你的个人电脑访问互联网。

操作步骤
第 1 步: 个人主机 - 启动代理

首先,让你的个人电脑具备代理功能。

  1. 安装 proxy.py:

    Bash

    复制代码
    pip install proxy.py
  2. 启动代理服务 (此终端需保持运行):

    Bash

    复制代码
    proxy --hostname 127.0.0.1 --port 8888

    看到 Listening on 127.0.0.1:8888 即成功。

第 2 步: 个人主机 - 建立隧道

打开一个新终端,运行 SSH 命令建立隧道。

Bash

复制代码
ssh -f -N -R 1080:127.0.0.1:8888 user@your-server-ip
  • -R 1080:127.0.0.1:8888: 核心参数。将服务器1080 端口流量,转发到本机8888 端口。

  • -f: 后台运行。

  • -N: 只建立端口转发,不执行命令。

输入密码后,隧道即在后台建立。

第 3 步: 服务器 - 配置并使用代理
  1. 登录服务器

  2. 设置代理环境变量:

    Bash

    复制代码
    export ALL_PROXY="http://127.0.0.1:1080"
    # 或者分别设置
    # export http_proxy="http://127.0.0.1:1080"
    # export https_proxy="http://127.0.0.1:1080"
  3. 验证代理:

    Bash

    复制代码
    curl https://www.google.com

    如能返回内容,说明代理成功。

  4. 执行你的命令:

    Bash

    复制代码
    uv pip install vllm
要点
  • 操作期间,第 1 步和第 2 步的两个终端窗口不能关闭

  • 使用完毕后,关闭个人主机上的终端,并在服务器上取消代理设置以恢复原状:

    Bash

    复制代码
    unset ALL_PROXY
    # unset http_proxy
    # unset https_proxy
相关推荐
2301_800256111 小时前
第九章:空间网络模型(空间网络查询、数据模型、Connected、with Recursive、pgRouting)
网络·数据库·算法·postgresql·oracle
xflySnail2 小时前
nas服务域名高速访问-DNS+ESA
运维·服务器·esa·无端口访问
猿小路8 小时前
抓包工具-Wireshark
网络·测试工具·wireshark
Rabbit_QL8 小时前
【网络设置】Docker 自定义网络深度解析:从踩坑到工程实践
网络·docker·容器
苏宸啊9 小时前
Linux指令篇(一)
linux·运维·服务器
浩子智控10 小时前
电子产品三防设计
网络·系统安全
我要升天!10 小时前
Linux中《网络基础》
linux·运维·网络
安科瑞刘鸿鹏1711 小时前
工业自动化系统中抗晃电保护的协同控制研究
运维·网络·嵌入式硬件·物联网
ZStack开发者社区11 小时前
ZStack Cloud 5.5.0正式发布
运维·服务器·网络
2501_9458374311 小时前
云服务器的防护体系构建之道
网络·安全