利用ssh反向代理以及autossh实现从外网连接内网
发布时间 - 2017-05-28 00:00:00 点击率:次前言
最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习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
-f 后台执行ssh指令 -C 允许压缩数据 -N 不执行远程指令 -R 将远程主机(服务器)的某个端口转发到本地端指定机器的指定端口 -L 将本地机(客户机)的某个端口转发到远端指定机器的指定端口 -p 指定远程主机的端口 ******************区分大小写啊各位亲******************
3. 首先在A上面操作:
建立A机器到B机器的反向代理,具体指令为
ssh -fCNR [B机器IP或省略]:[B机器端口]:[A机器的IP]:[A机器端口] [登陆B机器的用户名@服务器IP]
在这里我使用了B机器的7280端口,以及A机器的22端口,按照上面的指令就是这样子的操作
ssh -fCNR 7280:localhost:22 root@123.123.123.123
检验是否已经启动了可以使用ps aux | grep ssh指令来查看:
4. 接着在B上面操作:
建立B机器的正向代理,用来做转发,具体指令为
ssh -fCNL [A机器IP或省略]:[A机器端口]:[B机器的IP]:[B机器端口] [登陆B机器的用户名@B机器的IP]
按照第3那里输入的指令,这里的B机器的端口和上面的B机器的端口是一致的,端口1234的也是B机器的。
ssh -fCNL *:1234:localhost:7280 localhost
检验是否已经启动了可以使用ps aux | grep ssh指令来查看:
在此1234端口为本地转发端口,负责和外网进行通信,并将数据转发的7280这个端口,实现了可以从其他机器访问的功能。同时,*号表示可以接受任何IP的访问。
5. 展现奇迹的时候到了
至此我们都配置好了AB机器,那么我们就可以从一部外网的电脑登陆到内网里面去啦。鉴于我目前的电脑在内网,而服务器都是外网的(也就是配置的B机器),所以可以通过B机器连接到我内网的A中,具体指令为:
ssh -p1234 gdut728@123.123.123.123
在此-p参数为指定登陆的IP,我们在上面指定了1234端口为转发端口,故用1234端口登陆,然后gdut728是内网A机器的用户名,123.123.123.123为外网B机器的IP地址。
6. 这种反向代理的方式是不稳定的
不幸的是这种ssh反向链接会因为超时而关闭,如果关闭了那从外网连通内网的通道就无法维持了,为此我们需要另外的方法来提供稳定的ssh反向代理隧道。
6.1 ssh每次重连都需要键入密码,故在此首先设置免密码登陆到内网
在内网的机器A上面执行:
ssh-copy-id 内网用户名@外网IP -p指定转发的端口
按照之前我设定的端口,这个指令就是如下
ssh-copy-id gdut728@123.123.123.123 -p1234
那以后这台内网的A机器ssh登陆我外网的B机器就可以免密码登陆啦~
检验是否已经可以使用免密码登陆可以使用如下指令来检验:
ssh root@123.123.123.123
6.2 用autossh建立稳定隧道
centos7上没有默认安装autossh的,所以使用一下命令安装
yum install autossh
来看看具体的autossh的指令为
autossh -M 7281 -fCNR 7280:localhost:22 root@123.123.123.123
autossh的参数与ssh的参数是一致的,但是不同的是,在隧道断开的时候,autossh会自动重新连接而ssh不会。另外不同的是我们需要指出的-M参数,这个参数指定一个端口,这个端口是外网的B机器用来接收内网A机器的信息,如果隧道不正常而返回给A机器让他实现重新连接。
7. 最后配置在Linux上配置开机自动启动autossh,免去了重启Linux后要自己启动的autossh的麻烦
输入:
vi /etc/rc.d/rc.local
添加内容:
autossh -M 7281 -fCNR 7280:localhost:22 root@123.123.123.123
因为centos7之后,原来直接修改
/etc/rc.d/rc.local启动脚本自动生效的功能因为修改了需要重新赋予可执行权限
再输入 chmod +x /etc/rc.d/rc.local
8. 结言:
总算配置好了,目前不清楚会不会断线,明天看看什么情况再进行更新吧。如有不对之处,请大家指正提出~
参考以下网站
从外网 SSH 进局域网,反向代理+正向代理解决方案
使用SSH反向隧道进行内网穿透
# 内网
# 的是
# 可以使用
# 在此
# 都是
# 好了
# 在这
# 一台
# 里我
# 我在
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
JavaScript如何实现错误处理_try...catch如何捕获异常?
如何快速搭建FTP站点实现文件共享?
bing浏览器学术搜索入口_bing学术文献检索地址
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】
Bootstrap整体框架之JavaScript插件架构
Laravel如何自定义错误页面(404, 500)?(代码示例)
制作旅游网站html,怎样注册旅游网站?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何挑选高效建站主机与优质域名?
php json中文编码为null的解决办法
Laravel PHP版本要求一览_Laravel各版本环境要求对照
Laravel模型事件有哪些_Laravel Model Event生命周期详解
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
Swift中switch语句区间和元组模式匹配
Laravel怎么清理缓存_Laravel optimize clear命令详解
Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】
微信推文制作网站有哪些,怎么做微信推文,急?
Java遍历集合的三种方式
Linux安全能力提升路径_长期防护思维说明【指导】
如何快速生成可下载的建站源码工具?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
网站制作免费,什么网站能看正片电影?
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)
如何做网站制作流程,*游戏网站怎么搭建?
Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
油猴 教程,油猴搜脚本为什么会网页无法显示?
网站制作壁纸教程视频,电脑壁纸网站?
Laravel怎么生成URL_Laravel路由命名与URL生成函数详解
详解Android图表 MPAndroidChart折线图
Laravel如何优雅地处理服务层_在Laravel中使用Service层和Repository层
PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑
如何在新浪SAE免费搭建个人博客?
如何解决hover在ie6中的兼容性问题
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】
lovemo网页版地址 lovemo官网手机登录
如何用西部建站助手快速创建专业网站?
黑客如何利用漏洞与弱口令入侵网站服务器?
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
详解Android中Activity的四大启动模式实验简述
如何挑选最适合建站的高性能VPS主机?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
长沙企业网站制作哪家好,长沙水业集团官方网站?
微信h5制作网站有哪些,免费微信H5页面制作工具?
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】


P]