用于物联网设备的Linux发行版

简介: Linux是一个操作系统:该程序是控制计算机的核心。它决定如何在争夺它的所有其他程序之间划分可用资源(CPU,内存,磁盘,网络)。操作系统虽然非常重要,但它本身并没有用。其目的是管理其他程序的计算资源。没有这些其他程序,操作系统就无法实现很多目的。

11.06.18-Lunix-Distributions-1068x656-1.jpg

传统上,在选择用于部署Linux的发行版时,面临着很多麻烦。

什么是Linux发行版(Linux Distribution)

Linux是一个操作系统:该程序是控制计算机的核心。它决定如何在争夺它的所有其他程序之间划分可用资源(CPU,内存,磁盘,网络)。操作系统虽然非常重要,但它本身并没有用。其目的是管理其他程序的计算资源。没有这些其他程序,操作系统就无法实现很多目的。

这就是发行版的来源。发行版提供了许多其他程序,这些程序与Linux一起可以组装到工作集中用于多种用途。这些程序的范围从基本的程序编写工具(例如编译器和链接器,到通信库,再到电子表格和编辑器),到介于两者之间的几乎所有内容。发行版往往具有每个计算机或解决方案实际使用的超集。它还为用户或公司可以组合成他们认为是工作集的每种软件组件类别提供了许多选择。可以粗略地比喻为一家超市,在超市中货架上有很多物品可供选择,每个用户都可以从购物车中选择对他们有意义的物品。

基于二进制的分发还是基于源的分发

分发可以大致分为两类:基于二进制的和基于源的。

基于二进制的发行版提供了所有已经预编译并准备安装的软件组件。这些组件使用“足够好”的构建选项进行编译,这些选项对于大多数用户来说都可以正常工作。它们也确实为少数需要或想要编译自己的组件的用户提供了这些组件的资源。Debian,Fedora Core,OpenSUSE,Ubuntu和其他许多版本都体现了这种发行方式。尽管它们提供相同类型的系统,但它们都使用不同的方法(不幸的是,不兼容)来这样做。它们是服务器,台式机和笔记本电脑等通用计算机中使用的主要分发方式。

另一方面,基于源代码的发行版侧重于提供一个框架,在这个框架中,最终用户可以从源代码构建所有组件。这些发行版还提供了一些工具,可以方便地选择组件的合理起始集合,并根据需要调整每个组件的构建。这些调整可以简单到添加编译标志以使用不同版本的源或以某种方式修改源。用户将组装一个他们想要构建的菜单,然后开始构建。几分钟或几小时后,视情况而定,他们将得到一个系统软件,可以用于他们的计算机。这种发行版的例子有Gentoo、Android和Yocto。

通常,这些基于源的发行版通常对于嵌入式基于Linux的设备尤其是IoT设备是首选。 尽管它们难以设置和维护,但基于源的发行版具有独特的优势,即能够根据实际的目标硬件定制已安装的映像,以最大程度地利用资源或最大程度地减少资源浪费。 对于嵌入式设备而言,这往往是一个强大的约束。 此外,基于源代码的发行版更适合交叉构建(在该平台上,构建平台的计算机与在其上运行的计算机不同),而基于二进制的发行版则更适合于自托管构建。 您在同一台机器(或同一体系结构)上构建并运行。

鉴于当今普遍存在使用英特尔架构机器作为构建机器以及将ARM体系结构用于IoT产品的情况,跨构建支持对于IoT设备至关重要。

以容器为中心的发行版

传统的Linux方法只提供内核外部所有平台的单个统一用户空间。新模型是关于将用户空间组成一个“容器(containers)”的集合。容器化模型将用户空间的一部分转换为组件的联合集合,每个组件之间具有高度独立性。

容器化的linux发行版带来了许多好处,从允许团队更加独立地工作到使进行细粒度平台升级成为可能。缺点是它们比非容器化解决方案占用的空间更大。然而,如果说技术的发展给我们带来了什么启示的话,那就是当一项新技术的唯一缺点是它的占用空间时,其可用资源往往会扩大,从而使每一代新问题都变得越来越小。

下面将介绍一些早期的选项,以便与现有的发行版进行比较。

物联网的Linux发行版

现在,我们必须深入探讨有争议的领域。许多人拥有自己喜欢的Linux发行版,即使他们的需求发生了巨大变化(例如,从服务器设置更改为嵌入式IoT设备),他们仍然坚持使用该发行版。

我将在下面的列表中开始介绍:这是一些成熟的Linux发行版和一些后起之秀的示例。还有许多其他的存在,可能更适合一些用例。

Yocto

Yocto(https://www.yoctoproject.org/)是基于源的发行版,已在许多嵌入式和IoT设备中使用。它试图将基于二进制的发行版的好处(例如,将程序包及其依赖项明确分离)与基于源的发行版的好处结合在一起,后者使您可以在进行较小的更改时以显著的方式更改目标二进制文件。

1.png

Yocto由一系列配方(recipes)组成,每个配方都描述了如何构建系统的一个模块(例如,库,守护程序,应用程序等)。然后将这些配方收集到各层中,这些层收集一系列配方并配置应如何一起使用的各个方面,从编译标志到配方功能,再到有关它们如何显示在目标上的详细信息。每个目标构建都将由这些层中的一些层组成,每个层都在较低层中添加或删除软件包,或修改其默认行为。这允许多方调整他们自己的二进制映像以影响最终软件。 因此,如果基础层使用保守的一组编译器标志(通常这样做),则芯片供应商可以添加对其特定芯片模型有利的编译器标志,而主板供应商可以删除其主板可能不支持的芯片功能。

对于您的物联网产品,这实际上意味着您使用已经支持Yocto的主板来构建解决方案的努力将是添加或修改配方,以提供基本功能的增值。您还需要具有一个构建和配置管理基础结构设置,该设置允许您为目标创建映像,尽管在当今的容器世界中,这并不难做。

关于Yocto的更多信息,请从这里(https://www.yoctoproject.org/docs/2.5/overview-manual/overview-manual.html)开始。同样值得一提的是,在你考虑的物联网解决方案中,Yocto在任何开发板上的支持程度如何。

Debian

Debian(https://www.debian.org/)是一种古老的开源二进制发行版。它既是自身的发行版,也是其他知名衍生版本的基准,其中最著名的是Ubuntu(https://www.ubuntu.com/)。

Debian拥有大量为ARM(IoT的首选体系结构)预先构建的软件包,但考虑到Debian在英特尔生态系统中的优势,这些软件包对ARM二进制文件的支持和维护水平往往远低于英特尔的同类产品。因此,诸如“10000多个构建的包”这样的指标并没有那么有意义。您需要了解对您很重要的包以及它们的支持程度。

在自托管设置(例如Debian)中使用的许多发行版的一个缺点是,开发人员不理解或不记得包的安装可能不会在最终运行包的计算机上完成,因此他们不能依赖目标可用的任何功能。考虑到这种麻烦对于docker环境来说也是一个头疼的问题,发行版在清理这些依赖关系方面花费了大量精力,所以这是一个比以前更小的问题。

为少量软件包设置构建环境的工作相当琐碎,但是为系统构建所有软件包的基础架构可能会变得很重要。

由于这些原因,IoT的Debian是一个不错的选择,在这种情况下,您只需添加或创建一些软件包即可完成您的平台。

EdgeX Foundry

从严格意义上讲,EdgeX Foundry并不完全是一个发行版,因为它对发行版的BSP组件没有任何意见。BSP是包含Linux内核本身,设备驱动程序和用于启用硬件平台的库的部分。它从一个更高的级别开始,需要一个以docker支持为基础的可运行Linux系统。从那里开始,它提供了各种各样的容器,这些容器为IoT设备(尤其是边缘设备)提供了丰富的中间件和垂直集(在docker看来,容器是一个独立的模块,通常提供垂直功能,例如数据库或几乎不依赖主机操作系统、库等的网络服务)。

EdgeX Foundry背后的概念为大型IoT设备(尤其是边缘设备)指明了前进的方向,但是要定义更受约束的版本以提供一组良好的基准服务仍有待完成。在这方面已经取得了一些进展,一些服务已从JVM迁移到基于golang的实现,但是在不久的将来,对于基于低端和中端Linux的IoT来说,其覆盖范围仍然遥不可及。

Foundries.io Microplatform

linux-microplatform.jpg

Foundries.io使用基于Yocto的方法创建了一个Linux平台,以创建板支撑层,然后在其之上分层一组容器化的微服务。与EdgeX Foundry方法相比,它们的容器集更小,更适中,而且占用可见更小。

虽然可以通过订阅完全访问Foundries.io产品并进行自动更新和管理,但底层平台是开源的,并且是可用的。

小结

基于Linux的IoT正在从传统的嵌入式模型开始迁移,在传统的嵌入式模型中,将完整的垂直解决方案从单个团队/worldwiew/toolchain/model创建到更灵活的模型,其中固件,电路板,中间件和应用程序组件的分离程度更高。 但是,这种迁移并非没有代价,并且对CPU,内存和磁盘的要求也更高。 为了为您的下一个物联网项目选择Linux基准,您需要考虑您可以负担的占用空间和产品寿命。体积更小,更换速度更快的产品最好与Yocto等当今久经考验的真正解决方案保持一致。能够提供更多资源并需要将新功能部署到已部署产品中的产品应考虑使用更主流的Linux发行版和以容器为中心的新解决方案作为前进的道路。

原文链接

相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
相关文章
|
2月前
|
Web App开发 网络协议 安全
基于Web攻击的方式发现并攻击物联网设备介绍
基于Web攻击的方式发现并攻击物联网设备介绍
45 4
|
2月前
|
安全 物联网 物联网安全
智能物联网安全:物联网设备的防护策略与最佳实践
【10月更文挑战第26天】随着物联网(IoT)技术的快速发展,智能设备已广泛应用于智能家居、工业控制和智慧城市等领域。然而,设备数量的激增也带来了严重的安全问题,如黑客攻击、数据泄露和恶意控制,对个人隐私、企业运营和国家安全构成威胁。因此,加强物联网设备的安全防护至关重要。
114 7
|
3月前
|
物联网 5G 智能硬件
物联网卡:物联网卡不支持语音通话,是如何实现设备间的数据传输和通信的?
物联网卡(IoT SIM卡)通常被设计用于支持物联网(IoT)设备之间的数据传输,而不直接支持语音通话功能。这是因为物联网设备主要关注的是数据的收集、传输和处理,而不是语音通信。为了实现设备间的数据传输和通信,物联网卡及其背后的技术采用了多种方法,主要包括但不限于以下几种方式:
物联网卡:物联网卡不支持语音通话,是如何实现设备间的数据传输和通信的?
|
3月前
|
传感器 机器学习/深度学习 存储
物联网设备精细化管理系统解决方案
随着科技的进步,物联网技术作为新一代信息技术的核心部分,正在深刻改变各行业的生产和管理方式。其在资产管理、智慧城市、能源管理和智慧医疗等多个领域的广泛应用,不仅提高了运营效率,还促进了资源优化配置和精细化管理。本文详细介绍了物联网的基础概念及其在设备精细化管理系统中的具体应用方案,展示了如何通过智能感知层建设、数据处理分析平台以及精细化管理应用,实现设备的实时监控、预测性维护和能耗管理等功能,从而帮助企业提升竞争力,降低成本,并推动社会向更智能化、绿色化的方向发展。
108 2
物联网设备精细化管理系统解决方案
|
3月前
|
物联网
物联网卡不能使用在什么设备上
“物联网卡不能使用在什么设备上”这一操作或规定,通常基于物联网卡的特性、使用条款以及设备兼容性等因素。以下是对这一问题的详细分析和操作建议:
|
3月前
|
存储 监控 物联网
医疗物联网设备精细化管理系统解决方案
华汇数据智慧医院物联网管理系统解决方案是一种集物联网、云计算、大数据和人工智能等先进技术于一体的综合性解决方案,旨在提升医院的运营效率、医疗质量和患者满意度。
92 3
|
3月前
|
安全 物联网
物联网卡不能更换设备使用吗
物联网卡(IoT SIM卡)是否允许更换设备使用,这主要取决于物联网服务提供商的具体政策和服务条款。通常,物联网卡是为特定设备或应用场景设计的,因此一些服务提供商会限制卡的更换使用,主要是出于安全、管理、网络优化和避免滥用等考虑
|
4月前
|
安全 物联网 定位技术
2G网络和基站的撤销对物联网设备的影响
2G网络和基站的撤销对物联网设备的影响是多方面的,以下是对这一影响的详细分析:
2G网络和基站的撤销对物联网设备的影响
|
2月前
|
安全 物联网 物联网安全
智能物联网安全:物联网设备的防护策略与最佳实践
【10月更文挑战第27天】随着物联网技术的快速发展,智能设备已广泛应用于生活和工业领域。然而,物联网设备的安全问题日益凸显,主要威胁包括中间人攻击、DDoS攻击和恶意软件植入。本文探讨了物联网设备的安全防护策略和最佳实践,包括设备认证和加密、定期更新、网络隔离以及安全标准的制定与实施,旨在确保设备安全和数据保护。
83 0
|
3月前
|
物联网 数据安全/隐私保护
物联网:物联网卡不能使用在什么设备上
物联网卡是专为物联网设备设计的SIM卡,旨在连接非传统的、嵌入式或远程的设备到互联网。由于其特定的用途和设计,物联网卡并不适用于所有类型的设备,尤其是在以下几个方面,物联网卡通常不能或不建议使用在以下设备上:

热门文章

最新文章

相关产品

  • 物联网平台