当前位置:首页 > > IOT物联网小镇
[导读]各位看官好,上一篇文章我们聊了一下关于OTA升级过程中,新的软件包是如何从开发者的电脑上,安全的下载到嵌入式设备中的。这个流程似乎很简单,不就是下载一个文件而已嘛,怎么还值得写成一篇文章呢?其实这不仅仅是下载文件这么简单,这其中涉及到如何对众多的终端设备进行批量升级的策略问题。如...

各位看官好,上一篇文章我们聊了一下关于 OTA 升级过程中,新的软件包是如何从开发者的电脑上,安全的下载到嵌入式设备中的。


这个流程似乎很简单,不就是下载一个文件而已嘛,怎么还值得写成一篇文章呢?


物联网设备OTA软件升级之:完全升级和增量升级


其实这不仅仅是下载文件这么简单,这其中涉及到如何对众多的终端设备进行批量升级的策略问题。


如果你亲自在AWS的平台上操刀一次,就知道这其中有很多细节问题是需要考虑的。


一失足成千古恨哪!一旦设备升级策略忽略了一个小细节,也许某一天就是我们的深渊!


物联网设备OTA软件升级之:完全升级和增量升级包括产品的生产过程也是如此,那些踩过的坑,真是一把鼻涕一把泪,这个问题后面有时间专门写一篇。


今天,我们继续OTA升级过程中后续的阶段。


还记得我们之前的假设吗?


设备中正在执行的V1版本的程序,包括这3个文件,它们位于文件系统中的/root/app目录下:


main: 主程序;


config.ini: 配置文件(包括一个配置项:version=V1_0);


mylib.so: 实现了某个算法的动态库,被 main 程序调用;


现在,新的版本V2优化了算法,压缩包名称是app_V2.0.tgz,其中包括文件:


main: 没有变化;


config.ini: 配置项修改了:version=V2_0;


mylib.so: 优化了算法,主要就是想升级这个动态库;


upgrade.sh: 一个脚本程序,新增的文件;


升级包app_V2.0.tgz已经被下载到设备本地的文件系统中了,假设解压到目录/root/upgrade中。


现在需要做的事情就是:新版本程序,去替代/root/app目录中的旧版本程序。



upgrade.sh 升级脚本
我们首先要明白一个问题:执行升级指令、下载压缩包,都是此刻正在执行的main程序来执行的。


如果把复制替换的操作也让main程序来执行的话,肯定是会出问题的:它不可能去复制一个新的main文件,来把自己替换掉


物联网设备OTA软件升级之:完全升级和增量升级写过单片机程序的小伙伴肯定都知道:当新的固件下载到flash之后,一般都是重新启动设备,然后由bootloader来执行具体的文件复制操作。


那么对于带有文件系统的设备来说,也可以模仿类似的操作方式。


比如:当设备重新启动后,当执行/etc/rc.local时,此时main应用程序还没有启动。


此时就可以在rc.local这个文件中去做升级操作。


但是这样的方式,相当于是轻微的侵入了操作系统,总感觉这样做不太好。


此刻,upgrade.sh升级脚本开始登场了!


物联网设备OTA软件升级之:完全升级和增量升级这个脚本文件的主要作用就是用来控制升级过程


这里隐藏这一个很重要的思想:upgrade.sh是放在升级包中的,它并没有固化在终端设备中


这样的话,每次执行升级任务时,都可以根据本次的升级需要,来灵活的编写升级脚本。


换句话说:只要能保证升级的通道没有问题,那么升级的过程就完全由这个脚本文件来控制,你想怎么搞,就怎么搞!


物联网设备OTA软件升级之:完全升级和增量升级
完全升级
所谓的完全升级,就是把旧版本的程序全部丢弃,把升级包中的新程序全部复制过去。


此时,升级脚本文件upgrade.sh就完成下面这几个主要工作:


  1. 停止(kill)当前正在执行的 V1.0 版本的程序;


  2. 删除 /root/app 目录下的所有旧文件;


  3. 把升级包中所有的新版本文件 /root/upgrade/* 复制到 /root/app 目录下;


这样的完全升级方式是最无脑、最粗鲁的。


当然,还有一些细节问题是需要考虑的。比如:如果复制文件过程中出现错误怎么办?


还有一点,既然刚才提到了配置文件config.ini,不知您是否会有这样一个疑问:


如果配置信息被用户修改了,那么升级之后,所有的配置信息又被恢复为默认值了,用户的私人配置信息全丢了怎么办?


物联网设备OTA软件升级之:完全升级和增量升级关于这个问题,我们就继续来聊一下增量升级!



增量升级
所谓的增量升级:就是升级时并不会所有的文件全部进行替换,而只是替换那些需要更新的文件。


对于我们假设的升级场景,只需要做2件事情:


  1. 替换 mylib.so 库文件;


  2. 把配置文件 config.ini 中的版本字段修改为:version=V2_0;


同样的,所有的升级过程仍然是写在upgrade.sh这个升级脚本中:


  1. 停止(kill)当前正在执行的 V1.0 版本的程序;


  2. 把 /root/upgrade/mylib.so 文件复制到 /root/app 目录下;


  3. 使用 sed 命令来修改 config.ini 文件中的 version 字段;


PS:此时升级包中,只需要包含必要的文件就可以了,不需要把其他用不到的文件也放进去了。


物联网设备OTA软件升级之:完全升级和增量升级从我描述的文字来看,似乎完全升级和增量升级差别不大。


这是因为这里的示例太简单,如果是一个比较复杂的、有多个模块相互配合的应用程序,增量升级的优势就明显了。


关于OTA升级过程,就先说这么多了,主要是以思想为主,毕竟每一个项目的需求场景是不一样的,从大方向上明白OTA的升级过程就可以了。



One more thing
为了表示我不是在胡说八道,这里提供一个很多年前的项目中,升级脚本文件的模板。


在公众号后台留言:601,即可收到。


物联网设备OTA软件升级之:完全升级和增量升级另外,不知道是否有小伙伴对于ESP32中的升级流程感兴趣,下次再专门写一篇ESP32模组,如何与AWS后台通过MQTT指令进行交互,以及固件的下载升级流程。



------ End ------
本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭