0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

FOTA升级全流程教学:基于libfota2与第三方服务器搭建

合宙LuatOS 来源:合宙LuatOS 作者:合宙LuatOS 2026-01-19 18:35 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

远程固件升级不再是大厂专属,借助libfota2,你也可以为自己的设备搭建私有FOTA系统。本文将“手把手”带你完成从服务端搭建、固件包发布到设备端升级响应的完整流程。所有环节均基于第三方服务器实现,不依赖任何商业平台,适合有定制化需求的开发者参考与复现。

一、FOTA 概述

FOTA 即远程升级功能,此功能可以让用户在不方便大量线刷升级(设备不在身边/量产 PCB 没引出 USB/需要大批量进行功能升级)的情况下,快速进行底层固件/脚本/脚本 + 底层固件的远程更新。

LuatOS 开发模式下,固件分为两部分:core 和 script

远程升级时:升级 script 和 core+script ,仅 script 脚本升级时为全量升级,core+script 都升级时为差分升级

远程升级时:可以仅升级 script;也可以同时升级 core+script

支持 iot 平台升级和自建第三方服务器(HTTP)升级

二、演示功能概述

本文将详细讲述如何使用自建服务器服务器进行远程升级。另外此教程演示了自建服务器的三种升级相关场景:

(1) fota 升级简单演示:使用 iot 服务器进行远程升级功能模块,简单升级演示;

(2) tcp 服务器下发升级指令:通过 tcp 服务器下发升级指令(指令格式使用 json 字符串,包含是否升级参数),控制设备使用 fota 功能模块;

(3) psm 低功耗 fota:低功耗 fota 功能模块,此场景是针对 psm 状态下升级没完成就进入休眠导致升级失败的情况写的一个示例。

三、自有服务器 FOTA

FOTA 有多种方式,可以使用我们的 iot 平台进行升级,也可以使用用户自建平台升级,可以只升级 core,可以只升级用户脚本,也可以 core+ 脚本一起升级,接下来介绍自建服务器的升级。

3.1 网卡切换

fota 功能需要联网去下载升级包,所以需要选择一种联网方式:

netdrv_device:配置连接外网使用的网卡,目前支持以下四种选择(三选一)

(1) netdrv_4g:4G 网卡

(2) netdrv_eth_spi:通过 SPI 外挂 CH390H 芯片的以太网

(3) netdrv_multiple:支持以上三种网卡,可以配置三种网卡的优先级

在 netdrv_device.lua 文件中选择一种使用即可。

3.2 云平台配置

每一家的云平台都不一样,但是本质上都一样,都是给模块下发正确的升级文件。建议平台做一些验证,比如 imei 验证、版本号验证,循环请求验证,这样能够有效的避免因为升级包下载不对导致的模块循环升级,不跑代码其他逻辑,引起的假死机现象。

3.3 升级包制作并上传

自建服务器可以使用此服务器来做测试:http://airtest.openluat.com/download,该服务器只能上传文件,上传后可以获得一个下载链接,复制的链接用作自建服务器的 url。

所以我们在最开始先要生成一个链接,步骤如下:在进行脚本改动前,需要在你的电脑上随便生成一个.bin 后缀,大小不为 0 的文件(可以随便往里面写点什么),然后将这个 bin 文件上传到模块请求的地址去,目的是为了获取升级的 url。

wKgZO2lt9b6Acyb3AABBzerC6LI624.png

比如我的 bin 文件升级 url 为”http://airtest.openluat.com/download/FOTA2_DEMO_001.000.001_LuatOS-SoC_V2012_Air780EPM_1.soc“

3.3.1 单脚本升级

3.3.1.1 旧版本软件本地烧录

如果用户只是新增一些自己的脚本逻辑,没有更新底层,可以选择仅脚本升级

1.脚本中修改 url 为自己的升级 url,然后打开 luatools 的项目管理界面,点击生成量产文件,默认放在 luatools 根目录下的"SOC 量产及远程升级文件Air8000"目录下

注:一定要注意 url 前的"###"标志位,如果不加###,模块进行 HTTP 请求时,会在请求头里加上 version、project_key,imei,firmware_name 等参数

wKgZO2lt9iaAOJkzAAPxe6BqW_0958.pngwKgZPGlt9jyAMgtgAAIs73bKUKI545.pngwKgZPGlt9k2ANC5SAACc--a1Bcw765.png

2、将对应生成的 2010 版本,001.000.000 的 SOC 的固件烧录到模组中。

3.3.1.2 新版本软件级包制作并上传

1、因为模块烧录的是 001.000.000 版本,所以我们需要给脚本里的版本号改一下,改为 001.000.001 版本

wKgZPGlt9oGAH6viAAEJOTiHnQ4969.png

2、再将脚本中增加几行打印(为了模拟用户修改脚本的动作)

wKgZPGlt9qSARWQQAAE6hYTHh2I783.png

3、然后重新生成一次量产固件:

wKgZPGlt9seAdeZRAAHNCKFAlK8133.png

4、将升级文件改名成上面 url 中的文件名字 FOTA2_DEMO_001.000.001_LuatOS-SoC_V2010_Air780EPM_1.soc 。然后上传到服务器对应的地址。

3.3.2 含 core 升级

注意:对于不同后缀的固件,不能直接升级,分区有差异,强行升级可能无法启动。比如:LuatOS-SoC_V2012_Air780EPM_1.soc 只能升级LuatOS-SoC_V2014_Air780EPM_1.soc 后缀的固件,不能升级 LuatOS-SoC_V2014_Air780EPM_2.soc 后缀的固件。

3.3.2.1 旧版本软件本地烧录

每一次 core 的升级都会带来一些网络上的优化(例如信号差时的网络稳定性)以及一些 bug 修复,所以在发布新版本以后,用户可以先测试下 core 对自己脚本有无明显影响或性能提升,然后进行远程 FOTA。

1、本次选择脚本版本是 001.000.000,升级到 001.000.001;固件版本从 2010 升级到 2012 版本,

按照生成量产固件的步骤,001.000.000 版本脚本搭配 V2010 版本固件生成量产文件如下图:

wKgZO2lt9vqAcrDKAACc_ZY5rGw182.png

2、将对应生成的 2010 版本,001.000.000 的 SOC 的固件烧录到模组中。

3.3.2.2 新版本软件级包制作并上传

1、修改脚本版本后以及固件版本后重新生成量产固件如下:

需要注意的是:生成了这个版本以后,再去脚本中改动脚本版本号为 001.000.002(只要前后两位有一位大于 1,一位大于 0 即可(当然第一位大于 1 的时候,整个版本号自然大于 001.000.001),如 002.000.200;001.000.001;030.000.311 等)

脚本版本号分为 A.B.C 三段;

因为历史原因,中间这一段 B 没有任何意义,但是必须存在;

假设旧的脚本版本号为 A1.B1.C1,新的脚本版本号为 A2.B2.C2;

当新旧脚本版本号满足以下任何一种条件时,版本号允许升级:

(1)、A2 等于 A1,同时 C2 大于 C1;

(2)、A2 大于 A1,同时 C2 大于或者等于 C1;

(3)、B1 B2 无意义

wKgZO2lt92OANKSPAAEpg6AaLrQ360.png

2、接下来就是针对这两个量产文件,制作一个差分文件,用来远程升级(注:远程升级中 core 为差分,脚本为全量升级)

点击到 luatools 的主界面,依次点击图中蓝框所示意的地方(注:必须使用 luatools_3.0.9 及其以上版本,要不差分包升级的时候可能会出问题)

wKgZO2lt98WAZfpwAAFHrPo2IUE887.png

3、按下图所示选择低版本以及高版本的固件,然后点击开始执行即可,如果不想输出的差分包在 luatools 根目录下,可以自行选择一个输出路径

wKgZO2lt9-2AQBV9AAG36cqs0wY611.png

4、在你选择的目录下看到如下所示,带着脚本的 PROJECT core 版本号 脚本版本号的 bin 后缀的差分文件。

wKgZO2lt-A6AOc63AABOT_d0Zfs933.png

5、将升级文件上传完成以后,为了防止模块当前固件不是最早的版本,可以点击 luatools 主界面右边的"下载固件"选择最早的 001.000.000 版本,按住 boot 重启模块,然后点击下载,将最早的固件下载进模块里即可

6、将升级文件改名成上面 url 中的文件名字 FOTA2_DEMO_001.000.001_LuatOS-SoC_V2012_Air780EPM_1.soc 。然后上传到服务器对应的地址。

7、将对应生成的 2010 版本,001.000.000 的 SOC 的量产固件烧录到模组中。

3.4 示例结果展示

本 demo 将会演示三种场景下的 fota 升级,场景在 main.lua 中切换。

wKgZO2lt-D6AKDYlAAEiMEP9k8I589.png


3.4.1 场景一:fota 升级简单演示

主要代码如下:

wKgZPGlt-GaAe-wOABDqg2GccTg332.png

升级中:模块请求升级,下载完升级包以后会进行 MD5 验证升级包有无问题,如果没问题,就会启动重启程序,然后进行升级工作

wKgZO2lt-I6Ad7W_AARQ1sw_KIs689.png

升级后:升级成功后按我们之前的脚本,每隔 5S,打印一次"降功耗,找合宙"以及当前脚本版本号,可以看出,当前版本号已经由原来的 001.000.000 变为了 001.000.001,固件版本从 2010 变为 2012。

wKgZPGlt-LKAe4_BAAT5OgpHYr8282.png

3.4.2 场景二:tcp 服务器下发升级指令

通过 tcp 服务器下发升级指令(指令格式使用 json 字符串,包含是否升级参数),控制设备使用 fota 功能模块。此场景下,设备会先连接到 TCP 服务器,等待服务器下发升级指令。在 air_srv_fota.lua 中会有一个参数控制,防止升级过程中重复下载升级包。

测试服务器链接:https://netlab.luatos.com/,打开一个 tcp 服务器,

wKgZPGlt-PKAA24LAACrYQ36yBE350.png

在 tcp_self_main.lua 中配置 tcp 服务器信息:

wKgZO2lt-RGAGSgeAAFW8a4ygF0890.png

升级前:设备连接到 TCP 服务器,等待指令下发:{"fota": "true", "url": "http://airtest.openluat.com/download/FOTA2_DEMO_001.000.001_LuatOS-SoC_V2012_Air780EPM_1.soc"}

wKgZO2lt-UOAFRWoAADvCPTfSOI429.png

升级中:模组收到服务器下发的升级指令后,设备开始下载升级包并进行验证

wKgZO2lt-WCAG8akAAW5pHLRCVw589.png

升级后:升级包下载完成后设备重启升级,并循环打印新的版本号信息

wKgZPGlt-X6AUIeEAATDKHd8IBo078.png

3.4.3 场景三:psm 低功耗 fota

此场景是防止 psm 状态下升级没完成就进入休眠导致升级失败的情况写的一个例子。需要注意的是要等待升级成功后再去进入休眠。

主要代码如下:

wKgZO2lt-aiAXNA8ABH6CvjB03Y952.png

升级前:设备会在开机的时候去请求下配置的 url 的升级包,定期唤醒检查是否有升级任务

在此过程中模组会保持唤醒状态并等待升级包下载成功并校验通过,以及检查版本是否一致。如果版本不一致或升级包检验没通过则进入休眠等待下次唤醒检查升级包。没问题的话升级包下载成功后会重启并升级,升级流程如下:

wKgZPGlt-cuAK5GHAAT8TeCNoO4933.png

升级后:升级完成后设备显示新的版本号,并重新去请求升级包,没有新的升级包则会进入 PSM 状态

四、常见问题与注意事项

4.1 注意事项:

1、版本号格式:使用 IoT 平台时,项目的 VERSION 必须为 xxx.yyy.zzz 的三段数字格式(如 "001.000.001"),否则平台版本比对可能出错。

2、PRODUCT_KEY:使用 IoT 平台时,必须在 main.lua 中正确定义全局变量 PRODUCT_KEY,其值需从 IoT 平台的项目中获取。

3、重启时机:下载升级包成功(result 为 0)后,通常需要调用 rtos.reboot() 重启设备以更新。你可以根据需要延迟重启。

4、自建服务器规则

需要升级时,服务器应返回 HTTP 200,消息体为升级文件内容。

无需升级时,服务器应返回 HTTP 300 或以上的状态码。

5、固件类型:使用 IoT 平台进行脚本升级时,使用 Luatools 生成的 .bin 量产文件。

4.2 为什么升级后我的模块没有任何反应了,像是变砖一样

有多种可能,

4.2.1 检查脚本

首先先检查下用户自己的脚本,有可能是引起重启/死机的代码写在了最前面,例如新加的某个值或者函数为 nil 但是还是去做了些加减乘除或者判断大小的逻辑。可以直接本地烧录下新版本的 core+ 脚本验证,如果有 fskv 等用到 flash 的代码,可能需要仔细检查才能排除问题,比如下载的时候勾选如下图所示的两个选项。

4.2.2 检查 core

如果是仅脚本升级,但是没注意使用了新 core 中才有的接口,就有可能引起循环重启,如果重启在代码最开头,模块可能来不及打印任何日志就重启了,可以直接本地烧录下新版本的 core+ 脚本验证,如果有 fskv 等用到 flash 的代码,可能需要仔细检查。

4.3 检查过脚本和 core,没问题,为什么会循环升级 6 次以后禁止升级

检查下升级包是否正常,有时候因为人员误操作,经常会出现旧脚本 + 新 core 或者新脚本 + 旧 core 的意外组合,

例如:

本来应该如下表描述的一样

操作人员失误后变成了如下

然后误操作旧版本(1) 和误操作新版本(1)进行差分,这样虽然脚本版本号旧版本大于了新版本,但是 core 的旧版本小于新版本,所以升级平台依旧认为是依次有效的升级,下发了升级包。

升级完成后,模块内部脚本版本号变成了 001.000.000 core 版本号为 V2008,下次模块请求升级的时候,当前固件上报的脚本版本号(001.000.000)依旧小于云平台存储的脚本版本号(001.000.001),然后继续下发升级包,就这么循环 6 次,然后触发 iot 平台的禁止升级规则

wKgZO2lt-jmARGM0AAGrMSxTtiY406.png


在正确生成差分包,并且上传成功后,可以在 iot 平台里解除禁止升级的限制

在"我的设备"中选择升级 imei 所在的项目,然后点击右边的"解除禁止升级",

wKgZPGlt-lqAAuJ2AAFI97JUolg194.png

确定“导致设备循环升级的异常”已经处理完成后,点击确定解除,即可解除限制升级

wKgZO2lt-n6AQ55LAAIjk9A0VKY963.png


4.4 我想在服务器发送特定的字符串如"update"时再触发升级,应该怎么做

只需要在你希望的升级升级逻辑后面加上升级语句即可,例如mqtt 的 demo里增加几句话

wKgZO2lt5sWABzA6AAEn6T1IKZI221.png

又或者希望按键升级:

wKgZO2lt5wSAU6NVAACrLjElYZE183.png

4.5 如何处理同个项目外面有多个版本设备的升级情况

4.5.1 场景1:多种不同内核固件版本都要升级为最新版本内核固件+最新脚本

需要对每个版本都生成对应的差分包操作步骤: 现有A1、A2、A3三种内核固件需升级为B+新脚本: - 生成3个升级包:A1→B差分包+新脚本、A2→B差分包+新脚本、A3→B差分包+新脚本- 在合宙IoT平台创建3个升级配置,分别对应三类设备IMEI

4.5.2 场景2:多种不同内核固件版本+不同版本脚本都要升级为最新版本脚本,既只升级脚本。

操作步骤: 1. 准备完整的最新脚本(无需内核差分包) 2. 在IoT平台创建一个升级配置,指定所有需升级设备IMEI列表

4.5.3 升级规则说明

内核固件:仅支持差分升级

脚本:支持全量升级,可一次性完成


今天的内容就分享到这里了~

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 服务器
    +关注

    关注

    14

    文章

    10344

    浏览量

    91738
  • FOTA
    +关注

    关注

    0

    文章

    31

    浏览量

    8191
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    为什么MES企业要跟第三方机构合作设备数据采集?

    综上考虑,多数MES企业都不直接承接设备数据采集业务,而是选择和第三方机构合作。毕竟第三方机构长期耕耘这一领域,拥有成熟的产品体系、完善的技术路线以及专业的现场施工团队,能够快速应对各类现场难题,将
    的头像 发表于 03-19 15:03 836次阅读
    为什么MES企业要跟<b class='flag-5'>第三方</b>机构合作设备数据采集?

    苹果17可以无线充电吗?第三方配件怎么选?

    iPhone 17无线充电提升车载体验,支持Qi2.2,磁吸强、散热好,第三方配件需认准MFM认证。
    的头像 发表于 03-19 08:17 785次阅读
    苹果17可以无线充电吗?<b class='flag-5'>第三方</b>配件怎么选?

    零基础入门:用libfota2实现第三方服务器FOTA升级服务

     即使你是FOTA新手,也能通过本教程掌握远程固件升级的核心实现。我们以libfota2为客户端核心,结合自建第三方服务器,提供一份零基础可
    的头像 发表于 01-19 18:35 195次阅读
    零基础入门:用<b class='flag-5'>libfota2</b>实现<b class='flag-5'>第三方</b><b class='flag-5'>服务器</b><b class='flag-5'>FOTA</b><b class='flag-5'>升级</b><b class='flag-5'>服务</b>

    CW32W031调制频率的话有第三方软件工具么?

    请问,CW32W031调制频率的话,有第三方软件工具么?仿真软件也行
    发表于 01-19 06:54

    远传水电表对接第三方集中采集+远程抄表系统解决方案

    针对这一痛点,我们隆重推出 “远传水电表对接第三方集中采集+远程抄表系统”一体化解决方案,致力于打破技术壁垒,连通数据断点,让您的抄表项目轻松升级,一步到位。
    的头像 发表于 10-29 16:27 778次阅读
    远传水电表对接<b class='flag-5'>第三方</b>集中<b class='flag-5'>器</b>采集<b class='flag-5'>器</b>+远程抄表系统解决方案

    DEKRA德凯获得沃尔沃汽车第三方实验室认可资质

    近日,DEKRA德凯上海实验室成功通过沃尔沃汽车材料工程中心的严格评审,被正式列入其认可的第三方实验室名单。
    的头像 发表于 10-16 10:27 866次阅读

    SEGGER Ozone调试支持第三方调试工具

    SEGGER强大的Ozone调试和性能分析,长期以来一直深受J-Link和J-Trace用户的信任,现在可以支持第三方调试工具了。
    的头像 发表于 09-29 11:45 1384次阅读

    电子测试行业中的第三方检测机构如何解决平台灵活度低,维护困难等痛点问题?

    维护难,以及数据报告格式种类繁杂、产品对应软件开发耗时耗力等问题。而 ATECLOUD 智能云测试平台的出现,为该机构带来了转机,成功助力其优化第三方来料测试流程。​ 第三方检测机构测试 痛点剖析​ 产品与系统适配难题:该检
    的头像 发表于 08-06 17:07 958次阅读
    电子测试行业中的<b class='flag-5'>第三方</b>检测机构如何解决平台灵活度低,维护困难等痛点问题?

    如何集成第三方支付API到电商网站

    ​ 在电商网站中,集成第三方支付API是确保交易安全、提升用户体验的关键步骤。本文将逐步指导您完成整个流程,从选择支付提供商到上线后的监控。文章结构清晰,包含代码示例和实用建议,帮助您高效实现支付
    的头像 发表于 07-16 10:35 723次阅读
    如何集成<b class='flag-5'>第三方</b>支付API到电商网站

    天合跟踪获得DNV第三方风洞测试审查报告

    近日, 天合跟踪获得DNV颁发的中国支架行业首张风洞实验第三方审查报告。该风洞报告由天合跟踪与同济大学合作,针对开拓者1P跟踪支架进行了全新的刚性模型测压试验和先进动力学分析研究,并由DNV进行独立
    的头像 发表于 07-08 17:35 1085次阅读

    使用 Claroty SRA 优化第三方 OT 远程访问

    第三方,如原始设备制造商 (OEM) 技术员和维护承包商,是确保 OT 环境可用性、完整性和安全性的关键。负责服务 OT 资产的第三方经常远程工作。这意味着,他们会通过无数广泛使用的解决方案远程连接
    的头像 发表于 06-17 16:11 880次阅读
    使用 Claroty SRA 优化<b class='flag-5'>第三方</b> OT 远程访问

    第三方工业互联网平台有哪些

    第三方工业互联网平台有哪些
    的头像 发表于 06-14 15:48 1431次阅读

    钛和集团荣获零跑汽车第三方实验室资质认可

    近期,钛和集团顺利通过了浙江零跑科技股份有限公司(以下简称“零跑汽车”)对第三方实验室的能力验证及资质审核,助力零跑汽车实现“成为值得尊敬的世界级智能电动车企”的品牌愿景。
    的头像 发表于 06-13 17:00 1508次阅读

    钛和集团荣获吉利汽车第三方实验室资质认可

    近期,钛和集团汽车事业部顺利通过了浙江吉利控股集团有限公司(以下简称“吉利汽车”)对外部实验室的能力验证及资质审核,并获得了第三方实验室认可证书,助力吉利汽车实现“让世界充满吉利”的品牌愿景。
    的头像 发表于 06-10 15:03 1385次阅读

    SGS荣获比亚迪乘用车第三方实验室资质认可证书

    近日,国际公认的测试、检验和认证机构SGS(以下简称:SGS)位于重庆的标瑞新能源实验室(以下简称:SGS-CEC)荣获比亚迪乘用车实验室认可委员会(以下简称:比亚迪)颁发的“乘用车第三方实验室资质认可证书”。
    的头像 发表于 05-20 15:04 1216次阅读