百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

SSH除了远程连接还可以在命令行中做端口转发和反向远程端口转发

ccwgpt 2024-11-17 07:38 75 浏览 0 评论

通过远程连接的管理工具利用开启隧道的形式转发端口的做法,现在大家或多或少都用过吧。但是直接在命令行使用ssh添加-L或者-R的方式来进行代理或者反向代理转发,又有多少人试过呢?

ssh -Lssh -R 是 SSH(Secure Shell)命令的两个参数,它们用于设置端口转发。端口转发允许您通过一个安全的 SSH 连接将一个端口从一个网络转发到另一个网络。

下面通过假设下面的一个架构,来模拟演示如何不用图形软件仅在命令行中创建隧道转发端口。

一、ssh -L(本地端口转发)

-L 参数用于创建一个从本地机器到远程机器的端口转发。这种类型的转发通常用于将远程服务器上的服务转发到本地机器,以便可以安全地访问它。

语法

ssh -L 本地端口:远程地址:远程端口 用户名@远程主机
  • 本地端口:在本地机器上监听的端口。
  • 远程地址:远程机器的地址,可以是远程机器本机的 localhost或者远程机器可以访问到的其他机器的IP。
  • 远程端口:远程机器上的端口,您想要从本地访问的服务的端口。

例一: 假设您想要从本地机器安全地访问远程服务器上的 MySQL 数据库服务器,该服务器运行在远程服务器的 3306 端口上。

ssh -L 3306:localhost:3306 用户名@远程主机

这个命令会在本地机器上监听 3306 端口,并将其转发到远程主机的 3306 端口。然后,您可以在本地机器上使用 MySQL 客户端连接到 localhost:3306,实际上您连接的是远程服务器上的 MySQL 服务。

具体的运行效果:

假设mysql服务器在虚拟局域网中的IP为10.147.17.253

sean@MacBook-Pro ~ % ssh -L 3306:localhost:3306 root@10.147.17.253
The authenticity of host '10.147.17.253 (10.147.17.253)' can't be established.
ED25519 key fingerprint is SHA256:O/lqToPCh+PXli4FJkjumWlnltaq5UHmsLeKFhS8QgE.
This key is not known by any other names.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '10.147.17.253' (ED25519) to the list of known hosts.
root@10.147.17.253's password:
Last login: Wed Oct  2 10:41:06 2024 from 10.147.17.211
[root@databases ~]#

ssh连接成功后,就可以在本地通过映射的端口进行访问了

例二: 上面的例子中算了一个了解ssh转发的入门及例子。因为你都可以直接访问到数据库所在的服务器了,那么为什么不直接就访问器端口呢?

现在咱们让网络环境进一步的复杂化,如果现在虚拟局域IP为10.147.17.224的服务器不是mysql的服务器,而是一台跳板机,数据库是在跳板机同一网络中为192.168.1.98。要连接到数据库的命令就变成了这样:

sean@MacBook-Pro ~ % ssh -L 3306:192.168.1.98:3306 root@10.147.17.224
root@10.147.17.224's password:
Last login: Wed Oct  2 11:24:38 2024 from 10.147.17.211

如此也就可以在没有其他远程连接软件配置隧道的情况下,通过命令行打开SSH的端口转发,访问到跳板机内的其他服务。

二、ssh -R(远程端口转发)

-R 参数与 -L 类似,但它是用于创建从远程机器到本地机器的端口转发。这种类型的转发通常用于让远程服务器能够访问本地机器上的服务。

语法

ssh -R 远程端口:远程地址:本地端口 用户名@远程主机
  • 远程端口:在远程机器上监听的端口。
  • 远程地址:远程机器的地址(通常是 localhost)。
  • 本地端口:本地机器上的端口,您想要从远程服务器访问的服务的端口。

例子: 假设您想要从远程服务器访问本地机器上的 Web 服务器,该服务器运行在本地机器的 8880 端口上。

ssh -R 8880:localhost:8880 用户名@远程主机

这个命令会在远程机器上监听 8880 端口,并将其转发到本地机器的 8880 端口。然后,您可以在远程服务器上访问 localhost:8880,实际上您访问的是本地机器上的 Web 服务。

为了演示这个例子,咱们先在本地拉取一个nginx的镜像,然后将其映射到本地的8880端口,

sean@MacBook-Pro ~ % docker pull nginx:alpine
alpine: Pulling from library/nginx
43c4264eed91: Pull complete
5b19511a843d: Pull complete
652d69a25e85: Pull complete
51676974aef5: Pull complete
bb16f69e8876: Pull complete
6fb07faa0055: Pull complete
c298c5a0cd21: Pull complete
0c02f601d0ee: Pull complete
Digest: sha256:a5127daff3d6f4606be3100a252419bfa84fd6ee5cd74d0feaca1a5068f97dcf
Status: Downloaded newer image for nginx:alpine
docker.io/library/nginx:alpine

What's Next?
  View a summary of image vulnerabilities and recommendations → docker scout quickview nginx:alpine
sean@MacBook-Pro ~ % docker run -d -p 8880:80 --name demoweb nginx:alpine
b5065e9215161ff292c4e321ccb05df9518bf8a393d165d87e42eaf8480cd659
sean@MacBook-Pro ~ %

远程登录后成功后,远程即可通过其本地端口进行访问了

sean@MacBook-Pro ~ % ssh -R 8880:localhost:8880 root@10.147.17.224
root@10.147.17.224's password:
Last login: Wed Oct  2 11:26:50 2024 from 10.147.17.211
[root@desktop-centos ~]# curl localhost:8880
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html>

三、注意事项

  • 在使用端口转发时,您需要确保 SSH 服务端允许该类型的转发,并且您有足够的权限在两端设置端口转发。
  • 对于 -L-R 转发,您可能需要在 SSH 服务端的配置文件 /etc/ssh/sshd_config 中设置 AllowTcpForwarding yes
  • 如果您在防火墙后面,您可能需要在防火墙规则中允许转发的端口。

端口转发是 SSH 的强大功能之一,它可以帮助您安全地访问位于不同网络中的服务。



如果您对我的文章有兴趣,我把我发布的文章都归档到我私人网站中去,欢迎访问 Corner 三的小角落 -- 首页 查阅之前的文章。

相关推荐

如何让老师看完文章后还啧啧称奇?满分作文有框架,这3点是关键

历年来语文考试中,作文的分数都占着相当大的一个比例,同时作文也是最容易拉开差距的一个模块。别人拿满分,而你却只有20分左右,分数的差距就是这样拉开的。作文想拿很高的分数却是不容易,但不是完全不可能的事...

小学作文写作技巧和方法,万能公式框架法。家长收藏

小学语文老师用心整理,将写作框架编成万能公式。作文的写作是语文学习中的重要一环,从小学到初中再到高中,作文一直是语文考试中占分比重最高的部分。小学阶段的语文写作相对来说比较简单,主要是打基础,但是很多...

如何用爆款改写技巧提升文章吸引力结构重塑:打破原文框架悬念前

如何用爆款改写技巧提升文章吸引力?结构重塑:打破原文框架悬念前置法-在开头设置悬念或提出反常识的结论,吸引读者注意力。例如,将“接纳不完美是治愈的开始”改写为“天天逼自己当完美超人?别杠了!生活本就...

守护袁昆:是否有必要按框架去写文章,拍摄剪辑视频?

(文/守护袁昆)如今不管是写文章还是剪辑视频,越来越多的朋友喜欢用框架、用脚本,作为互联网创作者,我们是否有必要按框架去写文章,拍摄剪辑短视频呢?其实在内容创作过程中,是否使用框架始终是一个充满争议的...

揭秘!爆款文章的秘密:让读者无法抗拒的文章框架

说说我自己一开始写文章都会犯一个毛病,文章,通常是想到哪里,写到哪里,“管不住字儿”。这样往往会出现以下问题绊住我们继续写下去1、很容易,写着就跑偏了,最终出来的成品和最初的设想偏离很大2、会写得很慢...

想要写出逻辑清晰的文章,你需要掌握哪些写作结构

想要写出好文章,就必须要了解文章的结构和框架。一篇文章结构清晰,读者就很容易跟上作者的思路,看出文章的重点内容。如果你对新媒体的文章有进行过研究,你就会发现很多公众号的文章结构都是类似的。所以你需要掌...

写作结构拆解:从选题到框架,如何让文章说服力翻倍?

你有没有想过,为什么有些文章能轻松获得很高的阅读量,而你的文章却始终无人问津?其实,写出爆款文章并没有想象中那么难。关键在于选择一个吸引人的主题,并用一个清晰的写作框架,通过2-3个有力的子观点支撑...

申论怎么写?结构怎么弄?这篇文章是最基本的好文章框架

写作总被吐槽逻辑混乱?三步搭建框架法,新手也能写出漂亮文章

一、结构决定论:信息传递的桥梁写作者和读者之间始终存在一道隐形的鸿沟。作者脑海中的想法如同一棵枝繁叶茂的大树,但直接倾倒给读者时,往往只剩下零散的枝叶,信息在传达过程中的丢失,作者输出的和读者读到的不...

如何搭建文章框架:新手写作者很有必要看

#头条深一度-深度阅读计划#见面好呀,我是潼臻~37岁,边上班边带娃的二胎妈妈藏起生活里的琐碎,期望你我都能遇到更好的自己~~~~~~~~~~~~~~~~~~果然多读书是可以真切学习到有用的东西最近把...

模型上下文协议(MCP)的可视化向导

最近,模型上下文协议(MCP)引起了广泛关注。你一定听说过它。今天,让我们来了解一下它是什么。直观地说,MCP就像是AI应用的USB-C接口。正如USB-C提供了一种标准化的方式,用于将...

97个人放一页PPT!用对Smartart架构图直接开挂!

从讯飞出差回来的路上,在高铁上看到一条微博,关于红楼梦人物的思维导图:下面很多家长说,帮助很大,能帮助上学的孩子梳理清人物关系,我看了下,清楚是清楚,但真的不太好看!作为一名PPT博主,我就顺带在高...

技术架构规范与实践(二)架构设计示例

1.逻辑架构1.1领域概念1.2宏观应用架构1.3宏观流程1.4微服务拆分与分层2.技术架构3.开发架构3.1后端技术栈分类名称版本描述后端框架/组件JavaJdk8(openjdk:8u342)后...

倾斜柱模板安装加固

1、适用范围:呈梯形逐层向内侧倾斜的框架柱。2、工艺流程:定位放线-配模-校正梁位置-安装加固。3、工艺方法:(1)定位放线首先现场技术管理人员对每颗不同标高的梁底、梁中边线及200mm控制线进行平面...

地基与基础工程、主体工程节点构造

#去班味吧#桩头凿除环切法工艺说明:1、根据桩头预留长度(深入承台10cm)放样桩顶标高,施工人员根据测量结果在基桩上用红油漆标注环切线;2、在切割线以上部分桩底,人工用钢钎打入桩底约15cm,打入时...

取消回复欢迎 发表评论: