SSH Tunnel
本地转发(Local Forwarding)
本地主机通过 SSH Tunnel 访问远程主机的服务。(本地 -> 远程)
用例:远程服务器在 8888 端口启动了 JupyterLab 服务,本地主机访问本地 80 端口连接到远程服务器的 JupyterLab 服务。
ssh USER@HOST -CNf -L 80:localhost:8080 # 本地 80 -> 远程 8888
此时访问本地主机的 80
端口将会被转发到远程主机的 localhost:8888
端口。
-L
: 本地转发-C
: 此标志启用压缩,有助于减少资源消耗并加快速度。-N
: 不发送任何命令,只用来建立连接。-f
: 将 SSH 连接放到后台。避免长时间不用 SSH 连接时终端失去响应
可以通过 ps
命令找到 ssh 进程并通过 kill
命令来关闭隧道。
配置文件
可以通过配置文件来简化隧道的建立。编辑 ~/.ssh/config
:
Host local-forward
HostName example.com
User my_user
IdentityFile ~/.ssh/my_private_key
LocalForward 80 localhost:8888
Compression yes
ServerAliveInterval 60
ServerAliveCountMax 2
Host local-forward
:这是这个连接配置的别名,用在ssh
命令中作为目标主机的参数。HostName example.com
:实际主机名或 IP 地址。User my_user
:远程服务器的用户名。IdentityFile ~/.ssh/my_private_key
:用于身份验证的私钥文件路径。LocalForward 80 localhost:8888
:这是隧道配置的关键部分。它会将本地机器上的 80 端口转发到远程机器上的 8888 端口。当你在本地机器上访问 localhost 的 80 端口时,实际上是通过 SSH 隧道访问远程机器上的 8888 端口。Compression yes
: 启用数据压缩。ServerAliveInterval 60
:每 60 秒向服务器发送一次保活消息。ServerAliveCountMax 2
:在认定服务器不响应之前,允许发送保活消息的最大次数。
远程转发(Remote Forwarding)
远程主机通过 SSH Tunnel 访问本地主机的服务。(远程 -> 本地)
用例:内网服务器通过本地主机的 Clash 服务访问公网。
ssh USER@HOST -CNf -R 7000:localhost:7890 # 远程 7000 -> 本地 7890
此时远程主机访问 7000 端口会被转发到本地主机的 7890 端口,如果你在本地开启了 Clash 服务,那么远程主机就能通过这个 Clash 服务联网。
配置文件
Host reverse-forward
HostName example.com
User my_user
RemoteForward 7000 localhost:7890
RemoteForward 7000 localhost:7890
:配置远程端口转发。这条命令的意思是将远程服务器的7000
端口转发到本机的localhost:7890
端口。访问远程服务器的7000
端口就像访问本地的localhost:7890
端口一样。
动态转发(Dynamic Forwarding)
详见 socks5 代理
ssh USER@HOST -CNf -D 7890
此时如果在本地配置代理服务器为 socks5://HOST:7890
,则所有请求都将由远程主机代理发送。
配置文件
Host dynamic-forward
HostName example.com
User my_user
DynamicForward 7890
DynamicForward 7890
: 启用动态端口转发,并绑定本地的 7890 端口。