【运维】SSH 的 -L、-R 和 -D 选项

ssh | OpenBSD

-L 选项用于本地(Local)端口转发。

-R 选项用于远程(Remote)端口转发。

-D 选项用于动态(Dynamic)端口转发。

端口转发就是监听某一特定端口,然后将发往该端口的数据转发出去。

-L、-R 仅转发 TCP 报文,-D 支持 SOCKS5 协议,可以同时转发 TCP 和 UDP 报文。

假设有三台主机:

  1. 主机 A:本地主机,即 SSH Client 所在的主机;
  2. 主机 B:远程主机,即 SSH Sever 所在的主机;
  3. 主机 C:想要访问的目的主机。

主机上的端口:

  1. X 是主机 A 的端口,即本地端口;
  2. Y 是主机 B 的端口,即远程端口;
  3. Z 是主机 C 的端口。

-L 选项

-L 选项用法如下:

-L portX:hostC:portZ 或 -L *:portX:hostC:portZ 表示从任意主机发往主机 A 的端口 X 的流量,都通过主机 B,发往主机 C 的端口 Z。

-L localhost:portX:hostC:portZ 表示只有从主机 A 发往主机 A 的端口 X 的流量,才通过主机 B,发往主机 C 的端口 Z。

-L hostD:portX:hostC:portZ 表示只有从主机 D 发往主机 A 的端口 X 的流量,才通过主机 B,发往主机 C 的端口 Z。

上述这些命令执行后,主机 A 上的 SSH Client 就会开始监听本机 X 端口(TCP 协议)。

常见用法一:

ssh -L localhost:10086:hostC:80 root@hostB -NT  # 此处以主机 B 的 root 用户为例

在浏览器中访问 localhost:10086, 就可以实际访问到 hostC:80

常见用法二:

ssh -L localhost:10086:hostC:22  root@hostB -NT

在命令行执行 ssh -p 10086 root@localhost,实际连接上了主机 C 的 SSH Server。

-R 选项

-R 选项用法如下:

-R portY:hostC:portZ 或 -R *:portY:hostC:portZ 表示从任意主机发往主机 B 的端口 Y 的流量,都通过主机 A,发往主机 C 的端口 Z。

-R hostD:portY:hostC:portZ 表示只有从主机 D 发往主机 B 的端口 Y 的流量,才通过主机 A,发往主机 C 的端口 Z。

特别提醒:实际在默认设置下,并不能从任意主机或某一特定主机访问到主机 B 的端口 Y,而是只能在主机 B 上访问端口 Y。想要从任意主机或某一特定主机访问到主机 B 的端口 Y,需要将主机 B 的 /etc/ssh/sshd_config 文件中的 GatewayPorts 选项设为 yes,并重启 sshd。

上述这些命令执行后,主机 B 上的 SSH Server 就会开始监听本机 Y 端口(TCP 协议)。

常见用法:

主机 A 是你的私人电脑,你在主机 A 上搭建了一个本地网站,使用 80 端口;

主机 B 拥有公网 IP,任何人都可以访问。

只需要在主机 A 上执行如下命令:

ssh -R 8080:localhost:80 root@hostB

就可以在任意电脑上通过访问 hostB:8080,来访问主机 A 上的网站。

-D 选项

-D portX 或 -D *:portX 表示从任意主机发往主机 A 的端口 X 的流量,都通过主机 B,发往报文中目标主机的目标端口。

-D localhost:portX 表示只有从主机 A 发往主机 A 的端口 X 的流量,才通过主机 B,发往报文中目标主机的目标端口。

-D hostD:portX 表示只有从主机 D 发往主机 A 的端口 X 的流量,才通过主机 B,发往报文中目标主机的目标端口。

上述这些命令执行后,主机 A 上的 SSH Client 就会开始监听本机 X 端口。

除了 SSH Client 和 SSH Server,一般还需要一个辅助软件,用于截获 TCP 或 UDP 报文,并将它们导向主机 A 的端口 X。

假设有三台主机, IP 分别为:

  1. 192.168.10.1,主机 A
  2. 192.168.10.10,主机 B
  3. 192.168.10.100,主机 C

主机 C 上运行着 HTTP 服务器,网址为 192.168.10.100:80。

先在主机 C 上禁止主机 A 访问,这样主机 A 就不能访问主机 C 提供的网页了。

iptables -I INPUT -s 192.168.10.1 -j DROP
# 删除规则:iptables -D INPUT -s 192.168.10.1 -j DROP

在主机 A 上开启动态端口转发:

 ssh -D 10086 root@192.168.10.10 -NT

在主机 A 上设置 Socks5 代理(以火狐浏览器为例):Settings -- General -- Network Settings -- Settings…

在主机 A 的火狐浏览器上就可以访问到主机 C 提供的网页了。其中,

浏览器发出的 HTTP 请求被截获,发送到 SSH Client,这之间用的是 Socks5 协议;

从 SSH Client 到 SSH Server 这之间用的是 SSH 协议;

从 SSH Server 到主机 C 的 HTTP 服务器这之间用的是 HTTP 协议。

其它

autossh 软件可以监控 ssh 连接状态,并在断线时自动重连。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
运维变更管理流程是IT项目运维资料中的一个重要组成部分。它是指在IT项目运维过程中,对于运维变更的管理步骤和方法。在v1.3版本中,运维变更管理流程有以下几个关键步骤。 首先,运维变更管理流程的第一步是需求识别和评估。在这一步骤中,运维团队会与项目业务负责人沟通,了解需求变更的原因和影响范围,并进行评估,以确定变更是否合理和可行。 第二步是变更规划和设计。在这一步骤中,运维团队会制定变更计划,确定执行过程中所需的资源和时间,并制定详细的变更方案和测试策略。这一步骤的目的是为了确保变更顺利进行,能够满足业务需求。 第三步是变更实施和测试。在这一步骤中,运维团队会按照变更计划进行系统的更新、配置、安装或其他处理,并进行相应的测试,以确保变更不会对系统的稳定性和安全性产生负面影响。这一步骤的重点是确保变更的准确性和可靠性。 第四步是变更评估和审批。在这一步骤中,运维团队会对变更的实施结果进行评估,并进行相应的审批。评估的目的是检查变更是否达到了预期的效果,并在确保变更安全可靠的基础上进行批准。 最后一步是变更记录和文档管理。在这一步骤中,运维团队会将变更的详细记录和文档进行整理和存档,以备将来的参考和回溯。这样可以确保变更过程的可追溯性和可复现性。 通过以上的运维变更管理流程,IT项目运维团队能够有效地管理和控制运维变更的过程,确保变更的安全性、稳定性和可靠性,并提供变更过程的可追溯性和文档管理。这样可以最大程度地降低变更引起的风险和不确定性,确保系统的稳定运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值