访问局域网内设备的一个方案

本文介绍了一种通过云服务器中转实现从任意互联网接入点访问家庭局域网内Linux设备的方法,重点介绍了如何设置SSH隧道进行远程访问。

访问局域网内设备的一个方案

由于本人最近有需求访问自己家中的一台设备,家中宽带肯定不是公网IP,我需要在任何一个可以接入外网的设备上(设备B)访问到家中某台设备,是否可行,当然可行。这里主要说的访问指的是SSH终端访问。家中设备A为linux系统,且已安装好ssh。

方案目的

打通从任何一个接入到Internet的设备到家中设备的SSH通道

实现前提

  • 拥有公网IP的云服务器(国内外云服务器任你选)
  • 提前知道以下信息
    例如:
设备名IP用户名备注
A192.168.1.18admin-a家中设备
B10.2.5.128需要访问A的设备
CP.P.P.Padmin-c云服务器,用户名为ssh登陆用户名

实现步骤

  • 首先配置设备A
ssh -fCNR 8883:192.168.1.18:22 admin-c@P.P.P.P

其中8883为云服务器的端口号(可改,但要求前后保持一致),其作用是将A上的22端口绑定到云服务器上的8883端口,在设备A上终端输入该命令后会要求输入用户admin-c的密码。

  • 在云服务器(C)上配置ssh
ssh -fCNL "*:8888:localhost:8883" admin-c@P.P.P.P

其作用是建立正向代理,将云服务器的本地端口8888的数据转发给8883端口

  • 在设备B上登陆
ssh -p 8888 admin-a@P.P.P.P

其作用是登陆连接IP为P.P.P.P的设备的8888端口,登录名为admin-a。注意设备P.P.P.P会将请求转到其8883端口,而8883端口已经和我们家中的设备A的22端口绑定了,所有,最终我们请求登陆连接的是设备A的22端口,登陆名为admin-a,所有执行完后要求输入设备A的用户admin-a的密码,一切顺利的话,登陆成功。

利用jmdns发现局域网设备,在局域网内,你要通过一台主机和其他主机进行通信,你需要知道对方的ip地址,但是有些时候,你并不知道对方的ip地址,因为一般使用DHCP动态分配ip地址的局域网内,各个主机的IP地址是由DHCP服务器来帮你分配IP地址的。所以在很多情况下,你要知道对方的IP地址是比较麻烦的。 鉴于发现这篇文章最近的浏览量比较多,晚上也有不少转载,特别声明一下,文章水平可能不大够,只是我当时的一些理解,所以希望大家以批判的角度来看,然后又什么问题欢迎讨论。真心不希望误导大家^_^ mDNS就是来解决这个问题的。通过一个约定俗成的端口号,5353。(这个端口号应该是由IETF组织约定的。)每个进入局域网的主机,如果开启了mDNS服务的话,都会向局域网内的所有主机组播一个消息,我是谁,和我的IP地址是多少。然后其他也有该服务的主机就会响应,也会告诉你,它是谁,它的IP地址是多少。当然,具体实现要比这个复杂点。 比如,A主机进入局域网,开启了mDNS服务,并向mDNS服务注册一下信息:我提供FTP服务,我的IP是192.168.1.101,端口是21。当B主机进入局域网,并向B主机的mDNS服务请求,我要找局域网内FTP服务器,B主机的mDNS就会去局域网内向其他的mDNS询问,并且最终告诉你,有一个IP地址为192.168.1.101,端口号是21的主机,也就是A主机提供FTP服务,所以B主机就知道了A主机的IP地址和端口号了。 大概的原理就是这样子,mDNS提供的服务要远远多于这个,当然服务多但并不复杂。 在Apple 的设备上(电脑,笔记本,iphone,ipad等设备)都提供了这个服务。很多Linux设备也提供这个服务。Windows的设备可能没有提供,但是如果安装了iTunes之类的软件的话,也提供了这个服务。 这样就可以利用这个服务开发一些局域网内的自动发现,然后提供一些局域网内交互的应用了。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

blacklong28

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值