树莓派:漂洋过海来看你

简介: 作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁任何形式转载。   给树莓派连上显示器和键盘鼠标,就可以像使用一台电脑一样使用它了。但很多时候,我们是把体积小巧的树莓派当做一个便携设备来使用的。

作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁任何形式转载。

 

给树莓派连上显示器和键盘鼠标,就可以像使用一台电脑一样使用它了。但很多时候,我们是把体积小巧的树莓派当做一个便携设备来使用的。这种时候,用户可不希望随身带着体积庞大的鼠标、键盘和显示器。如果能用手中的电脑直接连接树莓派,然后用该电脑的输入输出设备来操纵树莓派电脑,就可以省去很多不必要的麻烦。除此之外,树莓派在物联网情境下的应用,也离不开多样的远程连接方式。

 

局域网SSH登陆

常见的家庭或办公网络都是以一个WiFi路由器为中心的。这种局域网场景下,可以很容易的用SSH的方式来远程登陆树莓派。SSH是用于远程服务器管理的加密协议。SSH分为服务器和客户端两端。树莓派将作为服务器端,而同一局域网下的另一台电脑可以作为客户端。客户端成功登陆之后,我们可以从客户端用命令行的方式来远程操作服务器端。

 

首先,我们需要开启树莓派上的SSH服务器。树莓派已经预装好了SSH服务器,我们只需要进入树莓派的设置页面开启就可以。从终端用命令行进入设置页面:

sudo raspi-config

然后在"5 Interfacing Options" -> "P2 SSH"中打开SSH服务器:

为了远程连接,我们必须知道树莓派的IP地址。在树莓派上,我们可以用ifconfig命令来找到树莓派的IP地址:

ifconfig

从ifconfig的输出中找到树莓派在局域网中的IP地址。比如ifconfig输出中给出了对应WiFi连接的wlan0端口地址为192.168.1.101。这个时候,就可以用同一局域网下的其他电脑来登录树莓派了。我们需要用这台电脑上的SSH客户端,比如说用UNIX下的ssh命令:

ssh pi@192.168.1.101

输入用户pi的密码,就可以远程登录到树莓派上。其实使用SSH客户端时,除了说明树莓派的IP地址,还需要一个端口号。在省略端口号时,客户端默认为端口22。在Windows下,可以使用PuTTy这样的SSH客户端软件。

 

Bonjour

但在上面的过程中,我们必须从树莓派本地运行ifconfig来查找它的IP地址,给远程登陆增加了不必要的麻烦。我们可以用局域网扫描工具来找到树莓派的IP地址。UNIX系统下提供了arp命令行工具,通过ARP协议来找到局域网下所有设备的MAC地址和对应的IP地址。此外,在不同的平台下也有很多图形化的局域网扫描软件,例如IPhone上的Fing、Mac OSX下的LanScan、跨平台的Angry IP Scanner,都可以帮助你列出同一局域网下所有设备的MAC地址和对应的IP。此外,你还可以登录路由器的管理页面。很多路由器都会列出连接设备及其IP。当然,通过这种方式得到的IP是一个列表,还要从中筛选出目标IP。如果局域网下设备较多,其过程还是比较痛苦。

 

更方便的,树莓派提供了对Bonjour的支持。Bonjour用于自动发现网络上的设备,可以实现局域网上的自动域名解析。在同一局域网下,可以用主机名.local的形式,找到对应的IP地址。由于树莓派的默认主机名是raspberrypi,因此可以用raspberrypi.local来登陆到树莓派:

ssh pi@raspberrypi.local

如果局域网内有多个以raspberrypi为名的主机,那么Bonjour将依次把它们称呼为:

raspberrypi
raspberryipi-2
raspberryipi-3
...

 

为了彻底避免主机名的冲突,你还可以重新命名树莓派的主机名。在raspi-config的设置页面中,选择"7 Advanced Options"->"A2 Hostname",更改主机名再重新启动树莓派,就能以新的主机名来进行Bonjour寻址。需要注意的是,Windows系统并没有自带对Bonjour的支持。你可以通过下载安装iTunes"Bonjour Print Services for Windows"来获得Bonjour功能。

 

Bonjour给设备了提供了一个动态域名,用于对应该设备的IP地址。在Mac OSX下,你可以用下面命令来查询背后的IP地址:

dns-sd -q raspberrypi.local

 

互联网SSH登陆

介绍了局域网和点对点情况下的SSH登陆,我们可以把野心放大一点,尝试在互联网环境中远程登陆SSH。我下面用几种不同的方式实现。

 

1)NAT端口映射

如果我们能拿到树莓派在互联网上的公网IP地址,那么就可以直接用一个命令SSH到该IP地址。问题是,现在大部分局域网络都用DHCP来给设备分配网内的私有IP,很可能只有网关才享有一个公网IP地址。有些网关允许设置基于NAT的端口映射。如下图所示,一组公网IP和端口号,能对应唯一的私网IP和端口号。这种情况下,我们就能从外网连接到局域网中的树莓派:

我们可以利用这一机制来找到树莓派,比如说,通过设置网关,让公网的199.165.145.1:8999对应私网的10.0.0.1:22。这里的199.165.145.1是网关的公网IP。10.0.0.1是树莓派的私网IP。22是SSH协议的默认端口。这时在互联网上的其他电脑上,就可以SSH连接到局域网中的树莓派:

ssh pi@199.165.145.1:8999

为了用该方法,我们的网关必须允许相关的端口映射设置。而很多网关出于安全考虑,完全不向外网开放类似的端口映射。因此,这一方法看似可行,但实践中会遇到很多困难。

 

2)REMOT3.IT

树莓派官网提供了一种简便的方法,即使用Weaved公司推出的REMOT3.IT。首先要在树莓派上安装相关的工具: 

sudo apt-get install weavedconnectd
sudo weavedinstaller

在安装过程中,REMOT3.IT会要求你输入REMOT3.IT网站的账户信息。树莓派上安装完成后,在REMOT3.IT网站登陆自己的账户,就能看到树莓派设备。如下图所示,网站会提供用于在互联网上连接到该树莓派所需的地址和端口号。根据地址和端口号,你就可以在任何一个连接到互联网的电脑上,用SSH客户端访问该树莓派。这个服务很好用,只恨该网站不但会限制树莓派数目,还会限制SSH连接的时间。想要避免这些限制,就需要缴费了。

3)SSH反向隧道

其实,类似于REMOT3.IT的技术不难自行实现。我们可以用SSH反向隧道(reverse tunneling)技术,从外网远程登陆树莓派。首先,让树莓派主动向公网服务器的某个端口发起SSH连接,比如vameilab.com:8999,形成一个SSH隧道。当我们使用互联网上的其他电脑,通过SSH连接到服务器的这一端口时,服务器会把通信内容接力到与树莓派的SSH隧道中,最终抵达树莓派。整个过程如下图所示。由于公网服务器的域名和IP地址都相对固定,我们也不用为找不到树莓派的IP地址而头痛。

SSH反向隧道

 

了解原理之后,我们也可以自行实现一个类似的中继服务器。你可以使用Amazon或阿里云的弹性云来架设中继服务器。你需要在云的控制台中开放用于反向连接的端口,如8999。从树莓派上用SSH命令建立反向隧道:

ssh -R 8999:localhost:22 vamei@vameilab.com

 

上面的命令,从树莓派的22端口到vameilab.com的8999端口建立反向隧道。登陆时用的vamei是中继服务器上的一个账户。反向隧道建立之后,你就可以从互联网上直接登陆树莓派了:

ssh -p 8999 pi@vameilab.com

 

总结

这篇文章介绍了点对点、局域网、互联网三个层面的远程登陆。在这三个层面上,树莓派还有很多种其他的远程登陆方式。我会在未来继续探索,并不断补充到这篇文章中。

 

欢迎阅读“骑着企鹅采树莓”系列文章 

目录
相关文章
|
安全 网络虚拟化 数据安全/隐私保护
Windows 10系统自带VPN客户端配置连接PPTP VPN服务器
Windows 10系统自带VPN客户端配置连接PPTP VPN服务器
6045 1
|
算法 数据处理 UED
带你读《2022技术人的百宝黑皮书》——APM 页面加载耗时校准(4)
带你读《2022技术人的百宝黑皮书》——APM 页面加载耗时校准(4)
237 0
|
存储 缓存 安全
SpringCloud微服务实战——搭建企业级开发框架(二十三):Gateway+OAuth2+JWT实现微服务统一认证授权
OAuth2是一个关于授权的开放标准,核心思路是通过各类认证手段(具体什么手段OAuth2不关心)认证用户身份,并颁发token(令牌),使得第三方应用可以使用该token(令牌)在限定时间、限定范围访问指定资源。   OAuth2中使用token验证用户登录合法性,但token最大的问题是不携带用户信息,资源服务器无法在本地进行验证,每次对于资源的访问,资源服务器都需要向认证服务器发起请求,一是验证token的有效性,二是获取token对应的用户信息。如果有大量的此类请求,无疑处理效率是很低,且认证服务器会变成一个中心节点
1725 57
SpringCloud微服务实战——搭建企业级开发框架(二十三):Gateway+OAuth2+JWT实现微服务统一认证授权
|
SQL cobar 算法
SpringBoot 2 种方式快速实现分库分表,轻松拿捏!
SpringBoot 2 种方式快速实现分库分表,轻松拿捏!
5741 6
SpringBoot 2 种方式快速实现分库分表,轻松拿捏!
Vite 使用inject/provide
Vite 使用inject/provide
165 0
|
存储 Java 应用服务中间件
Tomcat源码学习系列之一:Tomcat架构分析
本篇为Tomcat源码学习的开篇,主要通过阅读Tomcat的源码来了解其真正的运行流程以及原理,同时学习其中的架构设计等等。本文主要说明Tomcat的架构。 Tomcat架构 一次HTTP请求在tomcat中的流程 总结
Tomcat源码学习系列之一:Tomcat架构分析
|
Ubuntu Linux Shell
Docker和孤儿进程、僵尸进程
#Docker和孤儿进程、僵尸进程 ##前言 在unix/linux系统中,正常情况下,子进程是通过父进程fork创建的。子进程的结束和父进程的运行是一个异步过程,即父进程永远无法预测子进程到底什么时候结束。 当一个进程完成它的工作终止之后,它的父进程需要调用wait()或者waitpid()系统调用取得子进程的终止状态。 ### 孤儿进程 * 父进程先于子进程退出,那么子进程将
9928 0
|
机器人
奇葩设计师贾伟打开你的想象力经济
云栖TechDay活动第30期中,洛可可集团创始人&洛客(LKKER)创始人贾伟带来题为“想象力经济下的智能美学”的演讲。想象力经济时代已到来,本文从什么是想象力开始谈起,讲到想象力打造新消费生活,以及想象力打造绿色创新平台,最后也谈了想象力打造美学文化等。
6729 0
|
11天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1234 5
|
10天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
1215 87