ssh如何实现端口转发

SSH 可以通过端口转发(SSH Tunneling)实现将本地或远程的端口映射到另一台机器的端口。这通常用于在不直接暴露端口的情况下,通过 SSH 隧道访问某些资源。SSH 支持三种类型的端口转发:本地端口转发远程端口转发动态端口转发。下面详细介绍这三种方式:


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

本地端口转发允许你将本地计算机的某个端口通过 SSH 隧道转发到远程服务器上的指定端口。常用于通过堡垒机访问内部网络中的服务。

语法:
ssh -L [本地端口]:[目标地址]:[目标端口] [用户名]@[远程服务器]
示例:

假设你需要通过 SSH 访问内部网络中的 10.10.101.88:8080,但你只能通过 SSH 登录到堡垒机 bastion_host。你可以在本地创建一个端口转发,通过本地的 8080 端口访问内部服务。

ssh -L 8080:10.10.101.88:8080 your_username@bastion_host

解释:

  • -L 8080:10.10.101.88:8080:将本地的 8080 端口转发到堡垒机可访问的 10.10.101.88:8080
  • your_username@bastion_host:SSH 登录到堡垒机。

完成后,你可以通过本地的 http://localhost:8080 访问 10.10.101.88:8080 的服务。


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

远程端口转发允许你将远程服务器的某个端口转发到本地计算机或其他机器上的某个端口。这种方式常用于让远程机器访问本地的服务。

语法:
ssh -R [远程端口]:[目标地址]:[目标端口] [用户名]@[远程服务器]
示例:

假设你想将你本地的 Web 服务器(本地的 8080 端口)暴露给远程服务器 remote_host,使得 remote_host 上的用户可以通过访问 localhost:8080 来使用你本地的服务。

ssh -R 8080:localhost:8080 your_username@remote_host

解释:

  • -R 8080:localhost:8080:将远程服务器的 8080 端口转发到本地的 8080 端口。
  • your_username@remote_host:SSH 登录到远程服务器。

这样,remote_host 上的用户可以通过访问 http://localhost:8080 访问你本地的服务。


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

动态端口转发类似于本地端口转发,但它提供了更多灵活性,可以通过 SOCKS 代理将任何请求转发到指定的服务器。这种方式常用于建立代理服务器。

语法:
ssh -D [本地端口] [用户名]@[远程服务器]
示例:

假设你想通过远程服务器 remote_host 建立一个 SOCKS 代理,允许通过该代理访问多个目标服务器。可以使用如下命令:

ssh -D 1080 your_username@remote_host

解释:

  • -D 1080:在本地启动一个 SOCKS 代理服务器,监听 1080 端口。
  • your_username@remote_host:SSH 登录到远程服务器。

完成后,配置浏览器或其他工具使用 localhost:1080 作为 SOCKS 代理,你就可以通过该代理访问远程服务器所能访问的所有资源。


常用选项:

  • -N:只建立连接,不执行远程命令,适用于仅需要端口转发的场景。
    ssh -N -L 8080:10.10.101.88:8080 your_username@bastion_host
  • -f:将 SSH 进程放入后台运行,适用于长时间运行的端口转发。
    ssh -f -N -L 8080:10.10.101.88:8080 your_username@bastion_host

总结:

  • 本地端口转发:将本地端口转发到远程服务器的端口,适合通过中间主机访问远程服务。
  • 远程端口转发:将远程服务器的端口转发到本地或另一台主机的端口,适合让远程服务器访问本地资源。
  • 动态端口转发:通过 SOCKS 代理灵活地访问远程服务器上的资源,适合建立一个代理服务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1542082.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

基于SpringBoot+Vue的智慧物业管理系统

作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、SSM项目源码 精品专栏:Java精选实战项目源码、Python精…

SpringBoot3核心特性-核心原理

目录 传送门前言一、事件和监听器1、生命周期监听2、事件触发时机 二、自动配置原理1、入门理解1.1、自动配置流程1.2、SPI机制1.3、功能开关 2、进阶理解2.1、 SpringBootApplication2.2、 完整启动加载流程 三、自定义starter1、业务代码2、基本抽取3、使用EnableXxx机制4、完…

SaaS软件的配置化平台是如何实现个性化定制的?

SaaS(Software as a Service,软件即服务)是一种通过互联网提供软件的模式,用户无需安装和维护任何复杂的基础设施,只需通过网络连接即可使用软件。SaaS 供应商负责软件的维护、升级和可用性,用户则通过订阅…

智能体时代,AI正从“神坛”走向“人间”

从通用大模型到行业大模型:AI智能体引领新风口 在人工智能领域,一场深刻的变革正悄然发生。从昔日高高在上的通用大模型,到如今愈发接地气的行业大模型,AI的风向标已经鲜明地指向了AI智能体(AI Agent)&…

APO v0.4.0 发布:新增影响面分析;新增调用数据库指标;优化告警事件关联展示

APO 新版本 v0.4.0 正式发布!本次更新主要包含以下内容: 新增影响面分析,识别服务端点对服务入口的影响 服务入口是指业务被访问时调用的第一个服务端点,在调用拓扑图中处于最上游。服务入口直接反映了系统对外提供服务的状态&a…

基于SpringBoot+Vue+MySQL的手机销售管理系统

系统展示 用户前台界面 管理员后台界面 商家后台界面 系统背景 随着智能手机的普及和市场竞争的日益激烈,手机销售行业面临着前所未有的挑战与机遇。传统的手工记录和简单的电子表格管理方式已难以满足现代手机销售业务的需求,销售数据的混乱和管理效率低…

(done) 声音信号处理基础知识(2) (重点知识:pitch)(Sound Waveforms)

来源:https://www.youtube.com/watch?vbnHHVo3j124 复习物理知识: 声音由物体的振动产生 物体振动会导致空气分支振荡 某一处的空气气压变化会创造一个波 声音是机械波 空气的振荡在空间中传递 能量从空间中的一个点到另一个点 机械波需要媒介&#x…

DBNet 博客转载

论文地址:https://arxiv.org/abs/1911.08947 最后的文字概率还需要扩张d https://blog.csdn.net/weixin_46505265/article/details/134836652 https://paddlepedia.readthedocs.io/en/latest/tutorials/computer_vision/OCR/OCR_Detection/DBNet.html

ThreadLocal与AsyncLocal

简介 ThreadLocal 用于在多线程环境中创建线程局部变量,可以让每个线程独立地访问自己的变量副本,互不影响。 而 AsyncLocal 是 ThreadLocal 的异步版本,专门用于异步编程场景,在异步操作中它可以正确处理上下文切换。 ThreadLo…

【Python】探索 Elpy:Emacs 中的 Python 开发环境

可以短时间不开心,但别长时间不清醒。 对于使用 Emacs 编辑器的 Python 开发者来说,Elpy 是一个强大的集成开发环境(IDE),它通过整合多个 Emacs Lisp 和 Python 包,提供了一套完整的 Python 编程支持。本文…

MySQL基础篇的补充

前言: 查询语句的书写顺序 select > from > where > group by > having > order by > limit 查询语句的执行顺序 from > where > group by > having > select > order by > limit 这个很重要,提前再复习一下。…

vue入门小练习

文章目录 1.案例需求2.编程思路3.案例源码4.小结 1.案例需求 一个简易的计算器,其效果如下: 图片切换,其效果如下: 简易记事本,其效果如下: 2.编程思路 1.这个Vue.js应用实现了一个简单的计算器&#x…

检索索引对象中的重复值、删除重复值pandas.Index.duplicated

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 检索索引对象中的重复值、删除重复值 pandas.Index.duplicated [太阳]选择题 根据代码,下列哪个选项正确表示了去重后的结果? import pandas as pd idx pd.Index([1,…

图书管理系统小程序的设计

管理员账户功能包括:系统首页,个人中心,用户管理,图书分类管理,图书信息管理,我的待还处管理,图书归还管理,催还提醒管理,系统管理 微信端账号功能包括:系统…

如何实现接口幂等性?

概述 幂等,英文idempotent [aɪdempətənt] 幂等这个词源自数学,是数学中的一个概念,常见于抽象代数中,表达的是N次变换与1次变换的结果相同,在计算机的各个领域都借用了该概念 幂等函数或幂等方法,是指…

stm32单片机个人学习笔记6(EXTI外部中断)

前言 本篇文章属于stm32单片机(以下简称单片机)的学习笔记,来源于B站教学视频。下面是这位up主的视频链接。本文为个人学习笔记,只能做参考,细节方面建议观看视频,肯定受益匪浅。 STM32入门教程-2023版 细…

大模型Qwen2.5 家族的最新成员

阿里今天发布了 Qwen 家族的最新成员:Qwen2.5,包括语言模型 Qwen2.5,以及专门针对编程的 Qwen2.5-Coder 和数学的 Qwen2.5-Math 模型。 所有开放权重的模型都是稠密的、decoder-only 的语言模型,提供多种不同规模的版本&#xff…

某准网爬虫逆向

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、目标网站二、抓包分析 1.数据包2.逆向过程总结 前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不…

AI 时代的网络危机沟通计划

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

ICM20948 DMP代码详解(35)

接前一篇文章:ICM20948 DMP代码详解(34) 上一回终于解析完了inv_icm20948_initialize_lower_driver函数,本回回到icm20948_sensor_setup函数,继续往下进行解析。为了便于理解和回顾,再次贴出icm20948_senso…