本文摘自PHP中文网,作者大家讲道理,侵删。
前言
最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛。但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使用外网的小土豪就没有办法进入内网。这时能不能有一个办法可以使得通过外网连接到内网的服务器呢?答案是有的,不过这里就需要以下条件:一台在外网能访问到的服务器。
1. 描述一下目前的机器状况,梳理梳理:
机器 | IP | 用户名 | 备注 |
---|---|---|---|
A | 10.21.32.106 | gdut728 | 目标服务器,处于内网 |
B | 123.123.123.123 | root | 外网服务器,相当于桥梁的作用 |
PS:123.123.123.123只是我随意起的,大家请别攻击别人的服务器啊啊啊
2. 解决方法:
通俗地说:就是在机器A上做到B机器的反向代理;然后在B机器上做正向的代理实现本地端口的转发
2.1 实现前的准备
每台都要安装ssh的客户端。
在这里我使用的是centos7,都自带ssh。如果是使用其他版本Linux,请手动Google一下咯。
2.2 介绍一下使用到的ssh参数:
反向代理
ssh -fCNR
正向代理
ssh -fCNL
1 2 3 4 5 6 7 8 |
|
3. 首先在A上面操作:
建立A机器到B机器的反向代理,具体指令为
1 |
|
在这里我使用了B机器的7280端口,以及A机器的22端口,按照上面的指令就是这样子的操作
1 |
|
检验是否已经启动了可以使用ps aux | grep ssh
指令来查看:
4. 接着在B上面操作:
建立B机器的正向代理,用来做转发,具体指令为
1 |
|
按照第3那里输入的指令,这里的B机器的端口和上面的B机器的端口是一致的,端口1234的也是B机器的。
1 |
|
检验是否已经启动了可以使用ps aux | grep ssh
指令来查看:
相关阅读 >>
更多相关阅读请进入《SSH》频道 >>