SSH实现端口映射

news/2024/11/22 18:23:41/

SSH实现端口映射

SSH 端口映射(Port Forwarding)是一种通过 SSH 协议将本地端口或远程端口映射到另一个端口的方法,用于实现安全的网络访问。SSH 端口映射分为三种类型:本地端口转发远程端口转发动态端口转发


1. 本地端口转发(Local Port Forwarding)

本地端口的数据转发到远程服务器上的目标地址和端口。(访问本地端口就是访问远程端口)
用途:访问防火墙内部的服务,隐藏真实 IP,借助跳板机访问目标服务器等。

命令格式

ssh -L [本地端口]:[目标地址]:[目标端口] [用户名]@[远程主机]

参数说明

  • -L:指定本地端口转发。
  • [本地端口]:本地监听的端口。
  • [目标地址]:远程主机访问的地址(通常是 127.0.0.1,如果是通过跳板访问目标主机,那就是目标主机 IP )。
  • [目标端口]:远程主机的目标服务端口。
  • [远程主机]:用于建立SSH连接的主机。

示例
本地端口 8080 的数据通过 SSH 隧道转发到远程主机的 127.0.0.1:3306(MySQL)。

ssh -L 8080:127.0.0.1:3306 user@remote-server

访问 localhost:8080 即可连接到远程 MySQL 服务。


2. 远程端口转发(Remote Port Forwarding)

远程服务器的端口映射到本地机器的服务地址和端口
用途:允许外网访问内网资源。

命令格式

ssh -R [远程端口]:[目标地址]:[目标端口] [用户名]@[远程主机]

参数说明

  • -R:指定远程端口转发。
  • [远程端口]:远程主机监听的端口。
  • [目标地址]:本地服务的地址。
  • [目标端口]:本地服务的端口。

示例
将本地的 127.0.0.1:8000 服务映射到远程主机的 8888 端口。

ssh -R 8888:127.0.0.1:8000 user@remote-server

外部访问 remote-server:8888 即可连接到本地 8000 端口的服务。

注意:需要在远程服务器的 sshd_config 中设置 GatewayPorts yes,否则只能本机访问。


3. 动态端口转发(Dynamic Port Forwarding)

使用 SSH 作为 SOCKS代理 ,动态转发流量到不同的目标地址和端口。
用途:翻墙、代理上网。

命令格式

ssh -D [本地端口] [用户名]@[远程主机]

参数说明

  • -D:指定动态端口转发。
  • [本地端口]:本地监听的 SOCKS 代理端口。

示例
将本地 1080 端口作为 SOCKS5 代理,转发流量到远程主机。

ssh -D 1080 user@remote-server

在浏览器设置 SOCKS 代理为 localhost:1080 即可实现代理上网。


4. 常用附加参数
  • -f:让SSH在后台运行。
  • -N:仅建立转发,不打开shell。
  • -v:显示详细调试信息。
  • -C:启用SSH压缩,提高低带宽情况下的传输效率。

示例:后台运行本地端口转发。(实现本地 8080 端口访问远程 3306 端口的服务)

ssh -f -N -L 8080:127.0.0.1:3306 user@remote-server

5. 安全配置与注意事项
  1. 限制绑定地址:默认情况下,SSH 只监听本地的 127.0.0.1 ,可以通过 -g 选项允许其他主机访问。例如:

    ssh -g -L 8080:127.0.0.1:3306 user@remote-server
    
  2. 配置防火墙:确保相关端口未被防火墙阻拦。

  3. 调整 sshd 配置:编辑 /etc/ssh/sshd_config,确认以下设置:

    • 允许端口转发:AllowTcpForwarding yes
    • 动态转发:PermitTunnel yes
    • 远程绑定:GatewayPorts yes
  4. 测试连接:使用 telnetcurl 验证端口是否成功映射。


6. 排查问题
  • 端口冲突:确保本地或远程主机上的端口未被占用。
  • 防火墙限制:检查服务器和本地机器的防火墙规则。
  • 调试模式:使用 ssh -v 查看详细日志。

http://www.ppmy.cn/news/1549098.html

相关文章

招商蛇口|在低密园林里,开启生活的“任意门”

“最好的建筑是这样的,我们深处在其中,却不知道自然在哪里终了,艺术在哪里开始。” 凭借深耕西安10载的城市远见,以及建立在成功人居经验之上的敏锐洞察,招商蛇口将林语堂名言里的生活,变成了现实。 都市化越是加速&…

11.21 小清新图论专场训练

小清新 A 怎么感觉不是很简单呢 分析一下发现操作的自由度是很高的,不妨认为 一个连通块内不需要考虑边的方向,只需考虑当前是否还有空位 空位的判定条件就是是否已经加出一个环了 int n , L ; int a[N] , b[N] ; int bin[N] ; bool vis[N] ; int F…

三、计算机视觉_06YOLO基础知识

1、YOLO概述 1.1 定义 YOLO(You Only Look Once)是一种流行的对象检测和图像分割模型,由华盛顿大学的 Joseph Redmon 和 Ali Farhadi 于 2015 年推出,因其高速和准确性而迅速受到欢迎 在目标检测领域,传统方法&…

如何利用Java爬虫获得1688店铺详情

在数字化时代,数据已成为企业决策的重要依据。对于电商平台而言,获取竞争对手的店铺详情对于市场分析、产品定位等具有重要意义。本文将详细介绍如何利用Java编写爬虫,获取1688店铺详情,并提供实际的代码示例。 1. 背景介绍 1688…

五天SpringCloud计划——DAY1之mybatis-plus的使用

一、引言 咱也不知道为啥SpringCloud课程会先教mybatis-plus的使用,但是教都教了,就学了吧,学完之后觉得mybatis-plus中的一些方法还是很好用了,本文作为我学习mybatis-plus的总结提升,希望大家看完之后也可以熟悉myba…

IntelliJ+SpringBoot项目实战(十)--常量类、自定义错误页、全局异常处理

一、常量类 在项目开发中,经常需要约定一些常量,比如接口返回响应请求指定状态码、异常类型、默认页数等,为了增加代码的可阅读性以及开发团队中规范一些常量的使用,可开发一些常量类。下面有3个常量类示例,代码位于op…

【划分型DP-约束划分个数】力扣813. 最大平均值和的分组

给定数组 nums 和一个整数 k 。我们将给定的数组 nums 分成 最多 k 个非空子数组,且数组内部是连续的 。 分数 由每个子数组内的平均值的总和构成。 注意我们必须使用 nums 数组中的每一个数进行分组,并且分数不一定需要是整数。 返回我们所能得到的最…

【Springboot3 ➕Vue3】 实现学生选课管理系统

学生选课系统 介绍软件框架参考官方文档有话要说 介绍 简单的搭建一个学生选课平台--------作为开发练手的第一个项目 一共有三个系统角色:👇 管理员:管理员可以看到以上所有模块,管理所有模块信息。教师:教师可以…