脚本在Linux系统中具有很大的作用,在嵌入式Linux系统里,同样具有很大的作用,前面写过启动预留脚本、U盘自动运行脚本,今天介绍的是升级包中的脚本。
设计一个嵌入式Linux升级包
嵌入式Linux系统的升级包,可以升级内核、文件系统、应用程序、配置文件、资源文件等等,所以在设计升级包时,一定要考虑到可以升级多种文件载体,而不是只针对一种文件的升级。
记得刚毕业工作的时候,产品做升级功能,刚开始做了内核、文件系统、应用程序的升级包,后来由于客户需要,需要远程升级资源文件,然后就在升级类型中又加了一种类型,后来又要做配置升级,就又加了一种配置升级……这样导致平台上的远程升级方式有很多种,不利于使用和维护。
比较好的做法就是把升级的具体执行动作交给“升级包”,也就平台与设备之间,只是下载一个升级包就行了,至于是升级的内核、文件系统还是资源文件,平台和设备都不关注,具体的升级是由升级包自己完成的,那么这就需要升级包里有个“小的升级程序”,这也就是今天要讲的主角----升级包中的脚本。
那么这个升级包的基本结构配置就有了:
- 要升级的文件(镜像文件、配置文件、资源文件等等)
- 升级脚本
升级脚本
这个升级脚本就是这个升级包的关键,升级脚本的内容是根据升级的具体文件来定的,如果是升级内核,脚本里就写上升级内核的命令;如果升级文件系统,就写升级文件系统的命令,如果是升级资源文件,就写上替换资源文件的命令……这样就大大提高了升级包的灵活性。
脚本里包括以下几项基本内容:
- 启动升级命令
- 升级进度反馈
- 升级结果反馈
- 清除升级包临时文件
升级的进度和结果反馈,可以在系统里自己写一个和主程序通信的小程序,脚本可以调用这个小程序去反馈进度和执行结果。
升级执行流程
首先要制作一个升级包,升级文件和升级脚本打包添加校验和版本信息,参见前文介绍过的《制作一个嵌入式Linux的应用程序升级文件》,添加校验和版本信息,这样不用再添加额外的文件去记录这些信息了,便于传输和保存。
通过远程下载到设备或者U盘导入到系统里,然后通过主程序去校验升级文件和版本信息,然后解压升级包,启动升级脚本即可,剩下的升级过程就交给脚本去做了。