update.lua 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. --[[
  2. @module update
  3. @summary 远程升级功能模块
  4. @version 1.0
  5. @date 2025.08.12
  6. @author 孟伟
  7. @usage
  8. 实现远程升级功能,具体流程如下:
  9. 1、判断网卡是否连接成功;
  10. 2、初始化fota2模块;
  11. 3、配置fota2模块的参数;
  12. 4、调用fota2模块的升级函数;
  13. 5、在升级结果的回调函数中,根据升级结果进行处理;
  14. ]]
  15. -- 使用合宙iot平台时需要这个参数
  16. PRODUCT_KEY = "123" -- 到 iot.openluat.com 创建项目,获取正确的项目id
  17. libfota2 = require "libfota2"
  18. -- 循环打印版本号, 方便看版本号变化, 非必须
  19. function get_version()
  20. log.info("降功耗 找合宙")
  21. log.info("fota", "脚本版本号", VERSION, "core版本号", rtos.version())
  22. end
  23. sys.timerLoopStart(get_version, 3000)
  24. -- 升级结果的回调函数
  25. -- 功能:获取fota的回调函数
  26. -- 参数:
  27. -- result:number类型
  28. -- 0表示成功
  29. -- 1表示连接失败
  30. -- 2表示url错误
  31. -- 3表示服务器断开
  32. -- 4表示接收报文错误
  33. -- 5缺少必要的PROJECT_KEY参数
  34. local function fota_cb(ret)
  35. log.info("fota", ret)
  36. if ret == 0 then
  37. log.info("升级包下载成功,重启模块")
  38. rtos.reboot()
  39. elseif ret == 1 then
  40. log.info("连接失败", "请检查url拼写或服务器配置(是否为内网)")
  41. elseif ret == 2 then
  42. log.info("url错误", "检查url拼写")
  43. elseif ret == 3 then
  44. log.info("服务器断开", "检查服务器白名单配置")
  45. elseif ret == 4 then
  46. log.error("FOTA 失败",
  47. "原因可能有:\n" ..
  48. "1) 服务器返回 200/206 但报文体为空(0 字节)—— 通常是升级包文件缺失或 URL 指向空文件;\n" ..
  49. "2) 服务器返回 4xx/5xx 等异常状态码 —— 请确认升级包已上传、URL 正确、鉴权信息有效;\n"..
  50. "3) 已经是最新版本,无需升级" )
  51. elseif ret == 5 then
  52. log.info("缺少必要的PROJECT_KEY参数")
  53. else
  54. log.info("不是上面几种情况 ret为", ret)
  55. end
  56. end
  57. -- 使用合宙iot平台进行升级, 支持自定义参数, 也可以不配置,如果要配置参数可以参考此链接https://docs.openluat.com/osapi/ext/libfota2/
  58. local ota_opts = {}
  59. function fota_task_func()
  60. -- 如果当前时间点设置的默认网卡还没有连接成功,一直在这里循环等待
  61. while not socket.adapter(socket.dft()) do
  62. log.warn("fota_task_func", "wait IP_READY", socket.dft())
  63. -- 在此处阻塞等待默认网卡连接成功的消息"IP_READY"
  64. -- 或者等待1秒超时退出阻塞等待状态;
  65. -- 注意:此处的1000毫秒超时不要修改的更长;
  66. -- 因为当使用libnetif.set_priority_order配置多个网卡连接外网的优先级时,会隐式的修改默认使用的网卡
  67. -- 当libnetif.set_priority_order的调用时序和此处的socket.adapter(socket.dft())判断时序有可能不匹配
  68. -- 此处的1秒,能够保证,即使时序不匹配,也能1秒钟退出阻塞状态,再去判断socket.adapter(socket.dft())
  69. sys.waitUntil("IP_READY", 1000)
  70. end
  71. -- 检测到了IP_READY消息
  72. log.info("fota_task_func", "recv IP_READY", socket.dft())
  73. -- 这个判断是提醒要设置PRODUCT_KEY的,实际生产请删除
  74. if "123" == _G.PRODUCT_KEY then
  75. while 1 do
  76. sys.wait(1000)
  77. log.info("fota", "请修改正确的PRODUCT_KEY")
  78. end
  79. end
  80. log.info("开始检查升级")
  81. libfota2.request(fota_cb, ota_opts)
  82. end
  83. --创建并且启动一个task
  84. --运行这个task的主函数fota_task_func
  85. sys.taskInit(fota_task_func)
  86. -- 演示定时自动升级, 每隔4小时自动检查一次
  87. sys.timerLoopStart(libfota2.request, 4 * 3600000, fota_cb, ota_opts)