SSH 通过代理连接服务器

作者: 舌尖上的大胖 | 来源:发表于2018-03-27 22:29 被阅读0次

老规矩,先说结论:

# 用于 macOS,FreeBSD 未经测试
$ ssh -o ProxyCommand="nc -X connect/4/5 -x proxy.net:port %h %p" user@server.net

或者:

# 如果代理服务器需要认证,可以使用 nc 的升级版 ncat 指定代理服务器的用户名和密码
# 用于 Linux。在 macOS 上使用 ncat 无法连接,原因不明
$ ssh -o ProxyCommand="ncat --proxy-type http/socks4/socks5 --proxy proxy.net:port --proxy-auth proxyuser:proxypwd %h %p" user@server.net

一、背景

有些时候,由于网络限制等原因,不能直接连通过 SSH 连到指定服务器,需要经过代理进行连接。例如如下场景:

  • 客户机:client.net
  • 代理服务器:proxy.net,安装代理服务器软件,通过 1080 端口,提供 Socket5 代理服务
  • 目标服务器:server.net,在默认 22 端口,提供 SSH 服务

其中,
client.net 不能直接访问 server.net
client.net 可以访问 proxy.net
proxy.net 可以访问 server.net

二、解决方案

使用 SSHProxyCommand 选项,配合 nc/Ncat 命令,实现 client.net 通过代理 proxy.net,以 SSH 访问 server.net

1、连接代理工具

(1)nc

macOS 上常用这种方案。但是 nc 不支持需要认证的代理。

常用参数:

  • -X 指定代理协议
    • 4 SOCKS v.4
    • 5 SOCKS v.5(默认)
    • connect HTTPS proxy
  • -x 代理地址[:端口]
    如果没有指定端口,采用协议常用端口,如:
    • SOCKETS 使用 1080
    • HTTPS 使用 3128

(2)Ncat

Ncat 在 macOS 上通过代理连接时会出现连接断开的情况。

常用参数:

  • --proxy-type 指定代理协议
    • socks4 SOCKS v.4
    • socks5 SOCKS v.5
    • http HTTPS proxy(默认)
  • --proxy 代理地址[:端口]
    如果没有指定端口,采用协议常用端口,如:
    • SOCKETS 使用 1080
    • HTTPS 使用 3128
  • --proxy-auth 指定访问代理的账号、密码
    • 对于 --proxy-type http/socks5 形式为 --proxy-auth proxyuser:proxypwd
    • 对于 --proxy-type socks4 形式为 --proxy-auth proxyuser

2、SSH 命令行

nc 为例,如使用 Ncat 可以自行替换。

$ ssh -o ProxyCommand="nc -X 5 -x proxy.net:1080 %h %p" user@server.net

默认为 Socket5 代理,这时可以省略 -X 参数
或者采用另一种写法:

$ ssh -o "ProxyCommand nc -X 5 -x proxy.net:1080 %h %p" user@server.net

3、使用 SSH 配置文件

SSH 配置文件位置:

~/.ssh/config

增加如下两行内容:以 nc 为例,如使用 Ncat 可以自行替换。

Host *
    ProxyCommand nc -X 5 -x proxy.net:1080 %h %p

使用配置文件之后,就不需要在命令行中进行代理配置了。

三、其他解决方案

对于大部分情况,都可以直接使用 nc 或者 Ncat 解决。但对于一些复杂情况,也可以通过其它方案完成。如在 macOS 上想通过需要认证的代理连接,用 nc 无法实现,Ncat 又有些问题。

对于代理类型的问题,可以通过 Brook 来进行类型转换。

1、corkscrew

只支持 HTTP 代理

$ ssh -o ProxyCommand='corkscrew proxy.net 8888 %h %p' user@server.net

如需要访问带认证的代理服务器:

$ ssh -o ProxyCommand='corkscrew proxy.net 8888 %h %p ~/.ssh/myauth' user@server.net

~/.ssh/myauth 的内容:

username:password

2、proxytunnel

只支持 HTTP 代理

$ ssh -o ProxyCommand='proxytunnel -p proxy.net:8888 -P username -d %h:%p' user@server.net

命令行里只填用户名,会提示输入密码,或者通过环境变量传入。

四、参考资料

(完)

相关文章

  • SSH 通过代理连接服务器

    老规矩,先说结论: 或者: 一、背景 有些时候,由于网络限制等原因,不能直接连通过 SSH 连到指定服务器,需要经...

  • 通过代理连接ssh

    主要参考该篇文章,为了防止文章丢失,转载至此。 注意在进行./configure时在MAC下可能会错误,这个在别的...

  • Linux知识积累

    SSH连接 ssh通过跳板机连接内网服务器,发现能ping通连接不上,检查了/etc /ssh/ssh_confi...

  • 利用反向代理实现内网的ssh连接

    内容实现了再补 参考文章:SSH如何反向代理稳定穿透内网利用ssh反向代理以及autossh实现从外网连接内网服务器

  • 通过终端上传文件

    通过终端给云服务器上传文件 步骤1:通过ssh连接云服务器,修改/etc/ssh/ssh_config文件。将其中...

  • 监听端口被占用处理方式

    故事开始:我在校外连接学校服务器先用 Bitvise SSH Client 连接代理,再用 MobaXterm 连...

  • mysql连接安全性/ssh连接/云数据库连接

    mysql连接安全性/ssh连接/云数据库连接 root账户通过ssh连接,直接连接阿里云服务器;1. navic...

  • ssh连接远程Linux服务器

    ssh连接远程服务器 linux服务器一般默认的ssh端口号都为22,如果不是22端口则通过-p参数指定。连接方式...

  • ssh ProxyJump 通过代理机跳转内网

    ssh 通过代理机跳转内网 ssh 命令有一种简单的方法来利用跳板主机通过单个命令连接到远程主机。 ssh 可以使...

  • ssh反连接

    将本地服务器ssh断开映射到远程服务器10000端口 通过远程服务器1.1.1.1 ssh 10000端口即可连接...

网友评论

    本文标题:SSH 通过代理连接服务器

    本文链接:https://www.haomeiwen.com/subject/ikfecftx.html