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
相关推荐
invicinble8 小时前
对linux形成认识
linux·运维·服务器
技术路上的探险家8 小时前
8 卡 V100 服务器:基于 vLLM 的 Qwen 大模型高效部署实战
运维·服务器·语言模型
郝学胜-神的一滴8 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
半桔9 小时前
【IO多路转接】高并发服务器实战:Reactor 框架与 Epoll 机制的封装与设计逻辑
linux·运维·服务器·c++·io
绵绵细雨中的乡音9 小时前
深入理解 ET 与 LT 模式及其在 Reactor 模型中的应用
服务器·网络·php
HABuo9 小时前
【linux文件系统】磁盘结构&文件系统详谈
linux·运维·服务器·c语言·c++·ubuntu·centos
Howrun7779 小时前
关于Linux服务器的协作问题
linux·运维·服务器
暖馒10 小时前
Modbus应用层协议的深度剖析
网络·网络协议·c#·wpf·智能硬件
yunfuuwqi11 小时前
OpenClaw✅真·喂饭级教程:2026年OpenClaw(原Moltbot)一键部署+接入飞书最佳实践
运维·服务器·网络·人工智能·飞书·京东云
迎仔11 小时前
C-算力中心网络隔离实施方法:怎么搞?
运维·网络