关于ssh隧道使用

前言

对于一些很多之前不理解的地方,知道这个东西后才恍然大悟。比如为什么mysql默认监听地址是127.0.0.1,又或者vncserver 监听地址也是127.0.0.1,还有很多服务都是监听地址是127.0.0.1。

之前对于这种方式我都是将其改为0.0.0.0 ,让其监听的端口可以被外部直接访问,而不是通过本机才能访问到。

正确使用方式:应该是先用 ssh 端口转发,比如mysql 访问,先把远程的3306端口映射到本地 3306端口,然后再通过各种软件直接连接本地127.0.0.1:3306 就可以了。这种方式相当于你需要知道服务器密码,并且也需要知道你数据库密码,双重认证,更加安全。并且用完之后退出ssh隧道,在别人就完全访问不到3306端口了。

1.使用场景

接下来我用 服务在远程服务在本地 俩种描述方式,来描述使用场景。用 远程/本地 端口转发容易引发歧义

1.1 服务在远程

服务在远程服务器上,本地要访问

场景:服务器上有个vncserver 监听地址 127.0.0.1:5901

bash 复制代码
ssh -L 5902:localhost:5901 username@remote_server

连接后,直接访问本机 127.0.0.1:5902 来使用vnc服务

1.2 服务在本地

本地有个服务,远程服务器要访问

场景:本地上有个xserver 监听地址 127.0.0.1:6000

bash 复制代码
ssh -R 6001:localhost:6000 username@remote_server

连接后,远程服务器上访问 6001 可以访问到本地的xserver服务。

不过对于 xserver我们更多直接使用 X11Forwarding 来实现,不用额外的设置ssh隧道。

1.3 默认配置

如果不想每次都设置 -R -L ,也可以用配置文件实现 ~/.ssh/config

复制代码
Host myhost
    LocalForward 8080 localhost:80
    RemoteForward 9000 localhost:8000

设置好默认匹配host规则后,就可以对指定的ip or host生效了

相关推荐
志栋智能20 分钟前
超越监控:超自动化巡检提供的主动价值
运维·网络·人工智能·自动化
java_logo35 分钟前
2026 Docker 国内镜像加速配置教程
运维·docker·容器·docker镜像·docker镜像源·docker镜像加速·docker镜像国内库
搜狐技术产品小编202344 分钟前
破局与重构:纯端侧 Android 自动化引擎的尝试与未来推演
android·运维·重构·自动化
三十..1 小时前
Ceph分布式存储核心技术精要与运维实践指南
运维·分布式·ceph
tianyuanwo1 小时前
Jenkins × Gerrit 集成:自动触发构建的全流程解析
运维·servlet·jenkins
顾默@2 小时前
双系统Ubuntu18.04升级22.04,安装docker进行openclaw安装
运维·docker·容器
杨充2 小时前
1.1 数据编码设计原理
linux·运维·网络·底层原理·数据编码
一只鹿鹿鹿2 小时前
信息化项目管理规范(参考Word文件)
java·大数据·运维·开发语言·数据库
wanhengidc2 小时前
双线服务器有哪些优点?
运维·服务器
蜀道山老天师3 小时前
Docker Compose 多容器编排实战:LNMP、Tomcat 集群、云桌面、Portainer、Zabbix 一键部署
运维·docker·容器·tomcat·zabbix