ssh静态代理模式讲解与使用

--作者:飞翔的小胖猪

--创建时间:2021年5月18日

--修改时间:2021年5月23日

一、说明

SSH 为建立在应用层基础上的安全协议。SSH 是较可靠专为远程登录会话和其他网络服务提供安全性的协议。利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。

SSH除了日常用来登录控制其他设备外,自身还提供代理功能,以解决主机无法直接访问目的主机的跳转问题。可以称呼为代理也可以称呼为隧道。

1.1 代理模式

  • 正向代理(-L):相当于 iptable 的 port forwarding
  • 反向代理(-R):相当于 frp 或者 ngrok
  • socks5 代理(-D):相当于 ss/ssr

1.2 环境说明

1.2.1 主机列表

为了管理方便每一台服务器都有一个111网段的地址作用管理。只有主机A的网口及作为管理用也作为实验用。

其他服务器的111网段网口仅作为管理使用。每台服务器都安装有http服务,用作测试使用。

1.2.2 整体网络拓扑图

每个网段间的主机可以互相访问,不同网段的主机默认是不能互相访问的。

二、实际操作

2.1 正向代理

正向代理的也称为本地转发,使用把远程主机的指定端口映射到本地主机的指定端口,访问本地主机的端口时同等于访问远程主机的端口。

2.1.1 案例一

主机A通过主机B的端口访问到主机C监听在80端口的网页。

此案例的隧道开启操作在主机B上进行。

2.1.1.1  命令格式

主机B上启动一个B 端口,映射到 【主机C的C端口】上,这时访问 【主机B的B端口】相当于访问【主机C的C端口】,该功能类似于iptables的转发功能。

ssh -N -f -L 本地主机ip地址:本地主机端口:远程主机ip地址:远程主机端口 用户名@远程主机ip地址
说明:
      -L                       正向代理的标志参数
-N 命令不会登录到远程服务器上,会停留在本地服务器中,但是还是会占用一个终端。
-f 把命令放在后台运行,加了-f -N 参数,命令则不会登录到远端服务器上,会在本地服务器的后台运行。 本地主机ip地址 本地主机的端口监听的ip地址,默认是127.
0.0.1,如果监听在127.0.0.1则只有本主机可以使用这个端口跳转,就完全失去了代理的意义。 本地主机端口 本地主机用作映射远程主机的端口,此处选择一个未占用的大端口号。 远程主机ip地址 远程主机的ip地址 远程主机端口 远程主机已经处于监听的端口,也就是需要映射到本地主机的端口。 用户名 操作系统用户名,如root。

 注:

如果命令没有-N -f 参数命令使用过后会登录到户名@远程主机ip地址主机上,请保持这个终端正常运行,一旦终端退出则代理结束。所以-N -f 参数很重要。

使用 -N -f 参数时必须保证 -N -f 为ssh命令后第一二参数位,否则命令会报识别不了参数。

2.1.1.2  实际操作

操作前测试

hostA访问hostC结果。代理开启前,HostA不能访问hostC的网页。

hostB是否对待使用端口进行监听。代理前HostB的33333端口未使用。

开启隧道

在主机B上执行

jenkins@HOST_B:~$ ssh -N -f -L 0.0.0.0:33333:192.168.32.136:80 jenkins@192.168.32.136

结果

hostA通过hostB映射的端口能够正常访问到hostC上的网页。

代理开启后,HostB上的33333端口处于正常监听状态。

2.1.2 案例二

主机A可以通过自身的本地的端口经由主机B访问到主机C上监听在80端口的网页。

此案例的隧道开启操作在主机A上进行。

案例二和案例一的区别在于,案例一是在主机A上访问主机B的端口;案例二是在主机A上访问主机A的端口。

2.1.2.1  命令格式

主机A上启动一个A 端口,通过主机B映射到 【主机C的C端口】上,这时访问 【主机A的A端口】相当于访问【主机C的C端口】,该功能类似于iptables的转发功能,只是中间多了一层主机B的自动跳转。

ssh -N -f -L 0.0.0.0:主机A端口:主机C地址:主机C端口 用户名@主机B地址
说明:
      -L                       正向代理的标志参数
-N 命令不会登录到远程服务器上,会停留在本地服务器中,但是还是会占用一个终端。
-f 把命令放在后台运行,加了-f -N 参数,命令则不会登录到远端服务器上,会在本地服务器的后台运行。 主机A端口 本地主机用作映射远程主机的端口,此处选择一个未占用的大端口号。 主机C地址 远程主机的ip地址 主机C端口 远程主机已经处于监听的端口,也就是需要映射到主机A的端口。 主机B地址 能够同时连接主机A和主机C的中间主机,同时主机A能够访问的主机B的ip地址。

 注:

如果命令没有-N -f 参数,命令使用过后会登录到户名@主机B地址主机上,请保持这个终端正常运行,一旦终端退出则代理结束。所以-N -f 参数很重要。

使用 -N -f 参数时必须保证 -N -f 为ssh命令后第一二参数位,否则命令会报识别不了参数。

2.1.2.2  实际操作

操作前测试

hostA访问hostC结果。代理开启前,HostA不能访问hostC网页。

hostA是否对待使用端口进行监听。代理前HostB的33333端口未使用。

开启隧道

gitlab@Host_A:~$ ssh -N -f -L 0.0.0.0:33333:192.168.32.136:80 jenkins@192.168.111.130

结果

hostA通过hostB映射的端口能够正常访问到hostC上的网页。

代理开启后,HostA上的33333端口处于正常监听状态。

2.2 反向代理

反向代理的也称为远程端口转发,把主机的指定本地端口映射到远程主机的指定端口,访问远程主机的指定端口时同等于访问本地主机指定的端口。

2.2.1 案例一

主机C上有一个监控在80端口网页,此时我想通过主机A直接访问主机C上的80端口。但是需要在主机B上开启sshd的GatewayPorts。必须在开启隧道前提前开启,不开启该参数的话只有主机A的127.0.0.1能访问。

此案例的隧道开启操作在主机C上进行。

2.2.1.1  命令格式

主机C上运行隧道启动命令,把【主机C上C 端口】,映射到 【主机B的B端口】上,这时访问 【主机B的B端口】的等同于访问【主机C的C端口】。

ssh -N -f -g -R 远程ip地址:远程主机端口:本地主机ip地址:本地主机端口 用户名@远程主机ip地址
说明:
      -R                       反向代理的标志参数
-N 命令不会登录到远程服务器上,会停留在本地服务器中,但是还是会占用一个终端。
-f 把命令放在后台运行,加了-f -N 参数,命令则不会登录到远端服务器上,会在本地服务器的后台运行。
-g 开启网关功能,开启过后运行命令的主机所有网口都会监听对应端口。 本地主机ip地址 本地主机的端口监听的ip地址,默认是127.0.0.1,如果监听在127.0.0.1则只有本主机可以使用这个端口跳转,就完全失去了代理的意义。 本地主机端口 本地主机用作映射远程主机的端口,此处选择一个未占用的大端口号。 远程主机ip地址 远程主机的ip地址 远程主机端口 远程主机已经处于监听的端口,也就是需要映射到本地主机的端口。 用户名 操作系统用户名,如root。

 注:

如果命令没有-N -f 参数,命令使用过后会登录到户名@远程主机ip地址主机上,请保持这个终端正常运行,一旦终端退出则代理结束。所以-N -f 参数很重要。

使用 -N -f 参数时必须保证 -N -f 为ssh命令后第一二参数位,否则命令会报识别不了参数。

2.2.1.2  实际操作

操作前测试

hostA访问hostC结果。代理开启前,HostA不能通过主机B访问hostC网页。

开启隧道

开启sshd服务的网关功能,在hostB主机上,必须开启后再执行后续的hostC上开启隧道命令。

root@HOST_B:~# vim /etc/ssh/sshd_config    #在sshd_config配置文件中修改GatewayPorts为yes
GatewayPorts yes
root@HOST_B:~# systemctl restart sshd
jenkins@Host_c:~$ ssh -N -f -g -R 192.168.32.130:33333:0.0.0.0:80 jenkins@192.168.32.130

结果

hostA通过主机B能够正常访问到hostC上的网页。

代理开启后,HostB上的33333端口处于正常监听状态。

2.2.2 案例二

主机A可以通过自身的本地的端口经由主机B访问到主机C上监听在80端口的网页。此案例的隧道开启操作在主机B上进行。但是需要在主机A上开启sshd的GatewayPorts。必须在开启隧道前提前开启,不开启该参数的话只有主机A的127.0.0.1能访问。

此案例的隧道开启操作在主机B上进行。

2.2.1.1  命令格式

主机C上启动一个C 端口,映射到 【主机A的A端口】上,这时访问 【主机A的A端口】相当于访问【主机C的C端口】,注意和正向代理的案例二区分。

ssh -N -f -g -R 主机A地址:主机A端口:主机C地址:主机C端口 用户名A@主机A地址
说明:
      -R                       反向代理的标志参数
-N 命令不会登录到远程服务器上,会停留在本地服务器中,但是还是会占用一个终端。
-f 把命令放在后台运行,加了-f -N 参数,命令则不会登录到远端服务器上,会在本地服务器的后台运行。
-g 开启网关功能,开启过后运行命令的主机所有网口都会监听对应端口。

 注:

如果命令没有-N -f 参数,命令使用过后会登录到户名@远程主机ip地址主机上,请保持这个终端正常运行,一旦终端退出则代理结束。所以-N -f 参数很重要。

使用 -N -f 参数时必须保证 -N -f 为ssh命令后第一二参数位,否则命令会报识别不了参数。

2.2.1.2  实际操作

操作前测试

hostA访问hostC结果。代理开启前,HostA不能通过主机B访问hostC的网页。

开启隧道

开启sshd服务的网关功能,在hostA主机上,必须开启后再执行后续的hostB上开启隧道命令。

root@HOST_A:~# vim /etc/ssh/sshd_config    #在sshd_config配置文件中修改GatewayPorts为yes
GatewayPorts yes
root@HOST_A:~# systemctl restart sshd
jenkins@HOST_B:~$ ssh -N -f -g -R 192.168.111.129:33333:192.168.32.136:80 gitlab@192.168.111.129

结果

hostA通过本地端口能够正常访问到hostC上的网页。

代理开启后,HostA上的33333端口处于正常监听状态。

原文地址:https://www.cnblogs.com/Pigs-Will-Fly/p/14781459.html