SSH -L:安全、便捷、无边界的网络通行证

2023-12-31 00:20

本文主要是介绍SSH -L:安全、便捷、无边界的网络通行证,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欢迎来到我的博客,代码的世界里,每一行都是一个故事


在这里插入图片描述

SSH -L:安全、便捷、无边界的网络通行证

    • 前言
    • 1. SSH -L基础概念
      • SSH -L 的基本语法:
      • 端口转发的原理和作用:
    • 2. SSH -L的基本用法
      • 远程访问本地
        • 示例:访问本地Web服务
        • 示例:通过SSH跳板机访问内部服务
      • 本地访问远程
      • 示例:通过本地访问远程MySQL服务
    • 动态端口转发
      • 动态端口转发的基本语法:
      • 通过动态端口转发实现全局代理:
    • 最佳实践
      • 最佳实践:
      • 安全注意事项:

前言

在网络的无边际世界里,有时候我们需要突破种种限制,安全地穿越网络的边界。这就像是一场奇妙的冒险,而SSH -L则是你的导航仪。想象一下,就像在网络空间中挖掘一条安全通道,让数据安全、便捷地流动,就像在网络的边界开辟一扇神奇的门。

SSH -L 是一种SSH(Secure Shell)命令行选项,用于实现本地端口转发。本地端口转发是一种在安全通信通道中将本地计算机上的端口映射到远程服务器的指定端口的技术。这种功能对于建立安全的连接、绕过防火墙、访问内部网络服务等场景非常有用。

1. SSH -L基础概念

SSH -L 的基本语法:

ssh -L [local_bind_address:]local_port:remote_host:remote_port user@ssh_server
  • local_bind_address:本地绑定地址,通常是 127.0.0.1localhost。如果未指定,则默认为 localhost
  • local_port:本地计算机上要绑定的端口。
  • remote_host:远程服务器的主机名或IP地址。
  • remote_port:远程服务器上要映射的端口。
  • user@ssh_server:SSH服务器的用户名和地址。

端口转发的原理和作用:

端口转发是通过SSH安全通道将本地端口映射到远程服务器上的指定端口,从而实现安全的数据传输。这种技术有两种主要类型:本地端口转发(Local Port Forwarding)和远程端口转发(Remote Port Forwarding)。

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

    • 本地端口转发是将本地计算机上的端口映射到远程服务器上。当本地计算机上的应用程序连接到指定的本地端口时,SSH客户端会将流量加密并通过SSH通道传输到远程服务器上,然后将流量解密并转发到远程服务器上的指定端口。
    • 这种方式常用于访问远程服务器上的服务,如数据库、Web服务等,而不直接将这些服务暴露在公共网络中。
    ssh -L 8080:localhost:80 user@ssh_server
    

    上述例子中,本地计算机的端口 8080 被映射到远程服务器的本地地址(localhost)上的端口 80。

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

    • 远程端口转发是将远程服务器上的端口映射到本地计算机上。当远程服务器上的应用程序连接到指定的端口时,SSH客户端会将流量加密并通过SSH通道传输到本地计算机上,然后将流量解密并转发到本地计算机上的指定端口。
    • 这种方式可用于在远程服务器上访问本地计算机上的服务,如本地数据库、Web服务等。
    ssh -R 2222:localhost:22 user@ssh_server
    

    上述例子中,远程服务器的端口 2222 被映射到本地计算机的端口 22,允许在远程服务器上通过SSH连接到本地计算机。

总体而言,SSH的端口转发提供了一种安全、加密的通信通道,使得在不同网络中的计算机之间可以安全地共享服务和数据。

2. SSH -L的基本用法

远程访问本地

示例:访问本地Web服务

假设本地计算机上有一个运行在端口 8080 的Web服务,我们想通过SSH访问该服务。

ssh -L 8888:localhost:8080 username@remote_server
  • 8888 是本地计算机上要绑定的端口。
  • localhost:8080 是本地计算机上运行的Web服务的地址和端口。
  • username@remote_server 是远程SSH服务器的用户名和地址。

执行以上命令后,本地计算机上的端口 8888 将被映射到远程服务器上的本地地址(localhost)上的端口 8080。现在,可以通过访问 http://localhost:8888 来安全地访问本地计算机上运行的Web服务。

示例:通过SSH跳板机访问内部服务

假设我们有一个内部服务运行在内网中的机器上,而我们只能通过一个SSH跳板机来访问内网中的机器。

ssh -L 8888:internal_machine:80 jump_user@jump_server
  • 8888 是本地计算机上要绑定的端口。
  • internal_machine:80 是内网中运行的服务的地址和端口。
  • jump_user@jump_server 是SSH跳板机的用户名和地址。

执行以上命令后,本地计算机上的端口 8888 将被映射到内网中运行的机器上的端口 80。现在,可以通过访问 http://localhost:8888 来通过SSH跳板机安全地访问内网中的服务。

这些示例展示了如何使用SSH的本地端口转发功能,通过安全通道访问本地服务或内部网络中的服务。

本地访问远程

远程端口转发允许通过SSH在本地计算机上访问远程服务器上的服务。这对于在远程服务器上运行的应用程序和服务进行安全访问非常有用。以下是一个示例,演示如何使用SSH -L 进行远程端口转发,以通过本地计算机访问远程服务。

示例:通过本地访问远程MySQL服务

假设远程服务器上运行着一个MySQL服务,我们想通过本地计算机上的MySQL客户端访问这个远程MySQL服务。

ssh -L 3306:localhost:3306 username@remote_server
  • 3306 是本地计算机上要绑定的端口(本地MySQL客户端通常使用的端口)。
  • localhost:3306 是远程服务器上运行的MySQL服务的地址和端口。
  • username@remote_server 是SSH远程服务器的用户名和地址。

执行以上命令后,在本地计算机上的端口 3306 将被映射到远程服务器上的端口 3306。现在,可以在本地计算机上使用MySQL客户端连接到 localhost:3306,实际上是连接到远程服务器上运行的MySQL服务。

这个示例展示了如何使用SSH的远程端口转发功能,通过在本地计算机上创建远程端口映射,从而实现本地计算机访问远程服务器上的服务。

动态端口转发

SSH 的动态端口转发通过使用 -D 选项实现,它允许将本地计算机上的一个端口设置为 SOCKS 代理。这样,所有通过这个 SOCKS 代理的流量都会被加密并通过 SSH 通道传输到远程服务器上,然后再转发到目标服务器。这种方式允许创建一个安全的全局代理,用于访问互联网上的服务。

动态端口转发的基本语法:

ssh -D local_bind_address:local_port user@ssh_server
  • local_bind_address:本地计算机上要绑定的地址。通常使用 127.0.0.1localhost
  • local_port:本地计算机上要绑定的端口。
  • user@ssh_server:SSH 服务器的用户名和地址。

通过动态端口转发实现全局代理:

  1. 使用动态端口转发:

    ssh -D 1080 user@ssh_server
    

    这将在本地计算机上创建一个 SOCKS 代理,绑定到 127.0.0.1:1080。现在,本地计算机上的 1080 端口可以被用作全局代理。

  2. 配置浏览器使用代理:

    在浏览器中,配置代理以使用刚刚创建的 SOCKS 代理。在浏览器的网络设置中指定代理地址为 127.0.0.1,端口为 1080

    • Firefox 设置:

      1. 打开 Firefox 设置。
      2. 在“常规”选项卡中,找到“网络设置”。
      3. 点击“设置”按钮。
      4. 选择“手动代理配置”。
      5. 设置 SOCKS 主机为 127.0.0.1,端口为 1080
    • Chrome 设置:

      1. 打开 Chrome 设置。
      2. 点击“高级”。
      3. 在“系统”下找到“打开您的计算机的代理设置”。
      4. 在“局域网设置”中,选择“使用代理服务器”并设置 SOCKS 主机为 127.0.0.1,端口为 1080

现在,通过配置浏览器使用刚刚创建的 SOCKS 代理,整个浏览器的流量都将通过 SSH 加密通道传输到远程服务器上,从而实现了一个安全的全局代理。这种方式不仅可以用于浏览器,还可以用于其他支持 SOCKS 代理的应用程序。

最佳实践

使用SSH -L 进行本地端口转发时,有一些最佳实践和安全注意事项可以帮助确保连接的安全性和稳定性:

最佳实践:

  1. 最小化端口开放范围: 仅将必要的端口映射到远程服务器上,避免不必要的开放。只打开本地计算机上需要的端口,减少潜在的攻击面。

  2. 使用随机端口号: 选择不太容易被猜测的本地端口号,避免使用常用端口。这有助于增加安全性,减少被扫描到的风险。

  3. 限制绑定地址: 如果可能,将本地端口绑定到 127.0.0.1localhost,以限制只有本地计算机可以访问。这可以通过 -L 命令中的 local_bind_address 参数来实现。

  4. 使用公钥认证: 避免使用密码认证,使用SSH公钥认证可以提高安全性。确保在SSH服务器上配置了适当的认证方式,以防止未授权访问。

  5. 限制SSH用户权限: 为SSH用户分配最小必需的权限,确保他们只能执行必要的操作。使用 SSH 配置文件(sshd_config)中的 AllowUsersAllowGroups 选项来限制可以连接的用户或组。

安全注意事项:

  1. 防火墙设置: 在使用SSH端口转发之前,请确保防火墙设置允许SSH连接和端口转发。远程服务器、本地计算机以及中间的任何防火墙都需要适当的配置。

  2. 定期更新SSH软件: 保持SSH客户端和服务器软件的更新,以获取最新的安全性和性能修复。

  3. 使用SSH密钥保护私钥: 如果使用SSH密钥进行认证,确保私钥受到保护,并使用密码对私钥进行加密。定期更改密码,并确保只有授权用户可以访问私钥。

  4. 监控日志: 定期检查SSH服务器和客户端的日志,以便及时发现异常行为。检查登录尝试、连接和端口转发活动。

  5. 加密连接: 确保SSH连接是加密的,以保护传输的数据。避免使用不安全的加密算法,推荐使用较新、安全的算法。

  6. 双重检查连接参数: 在建立SSH连接之前,仔细检查连接参数,确保端口和地址等都正确。防止因输入错误导致不安全的连接。

  7. 谨慎使用全局代理: 如果使用SSH动态端口转发作为全局代理,确保只有信任的流量通过代理。防止未经授权的流量通过代理进入网络。

通过遵循这些最佳实践和注意事项,可以提高使用SSH -L 进行本地端口转发时的安全性,并确保连接的稳定性。

这篇关于SSH -L:安全、便捷、无边界的网络通行证的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/554447

相关文章

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

客户案例:安全海外中继助力知名家电企业化解海外通邮困境

1、客户背景 广东格兰仕集团有限公司(以下简称“格兰仕”),成立于1978年,是中国家电行业的领军企业之一。作为全球最大的微波炉生产基地,格兰仕拥有多项国际领先的家电制造技术,连续多年位列中国家电出口前列。格兰仕不仅注重业务的全球拓展,更重视业务流程的高效与顺畅,以确保在国际舞台上的竞争力。 2、需求痛点 随着格兰仕全球化战略的深入实施,其海外业务快速增长,电子邮件成为了关键的沟通工具。

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

git ssh key相关

step1、进入.ssh文件夹   (windows下 下载git客户端)   cd ~/.ssh(windows mkdir ~/.ssh) step2、配置name和email git config --global user.name "你的名称"git config --global user.email "你的邮箱" step3、生成key ssh-keygen