開(kāi)源項(xiàng)目 OpenHarmony是每個(gè)人的 OpenHarmony
黃騰坤
誠(chéng)邁科技驅(qū)動(dòng)開(kāi)發(fā)工程師
萬(wàn)帆
誠(chéng)邁科技應(yīng)用開(kāi)發(fā)工程師
OTA簡(jiǎn)介
隨著設(shè)備系統(tǒng)日新月異,用戶如何及時(shí)獲取系統(tǒng)的更新,體驗(yàn)新版本帶來(lái)的新的體驗(yàn),以及提升系統(tǒng)的穩(wěn)定性和安全性成為了每個(gè)廠商都面臨的嚴(yán)峻問(wèn)題。OTA(Over the Air)提供對(duì)設(shè)備遠(yuǎn)程升級(jí)的能力。升級(jí)子系統(tǒng)對(duì)用戶屏蔽了底層芯片的差異,對(duì)外提供了統(tǒng)一的升級(jí)接口。基于接口進(jìn)行二次開(kāi)發(fā)后,可以讓廠商的設(shè)備(如IP攝像頭等)輕松支持遠(yuǎn)程升級(jí)能力。OTA升級(jí)包類型
升級(jí)包常見(jiàn)有3種類型,主要包括:全量升級(jí)包、差分升級(jí)包以及變分區(qū)升級(jí)包。 ? ?全量升級(jí)包:升級(jí)包中只包括鏡像全量升級(jí)相關(guān)數(shù)據(jù),用于鏡像全量升級(jí); ?差分升級(jí)包:升級(jí)包中只包括鏡像差分升級(jí)相關(guān)數(shù)據(jù),用于鏡像差分升級(jí); ?變分區(qū)升:升級(jí)包中包括分區(qū)表、鏡像全量數(shù)據(jù),用于變分區(qū)處理和變分區(qū)后的鏡像恢復(fù)。 ?適用范圍
OpenAtom OpenHarmony(簡(jiǎn)稱“OpenHarmony”) 3.1 Release不支持富設(shè)備升級(jí),本章節(jié)所有實(shí)例在OpenHarmony 3.2 Beta3上驗(yàn)證,升級(jí)方式為全量升級(jí),所用開(kāi)發(fā)板為誠(chéng)邁科技基于RK3568設(shè)計(jì)的HCPAD-100開(kāi)發(fā)板以及OpenHarmony主干使用的DAYU200開(kāi)發(fā)板??墒褂肏CPAD-100開(kāi)發(fā)板或DAYU200開(kāi)發(fā)板驗(yàn)證,patch已提供,其他開(kāi)發(fā)板可能存在差異,請(qǐng)自行驗(yàn)證。OTA升級(jí)步驟
?1.制作升級(jí)包(update_packaging_tools需切換至master分支) 1.1 創(chuàng)建目標(biāo)版本(target_package)文件夾,文件格式如下: ? 1.2 將待升級(jí)的組件,包括鏡像文件(例如:system.img)等放入目標(biāo)版本文件夾的根目錄下,代替上文結(jié)構(gòu)中的{component_N}部分。 1.3 填寫(xiě)“updater_config”文件夾中的組件配置文件。 1.3.1 配置“updater_config”文件夾中當(dāng)前升級(jí)包支持的產(chǎn)品list:BOARD.list。
RK3568
1.3.2 配置“updater_config”文件夾中當(dāng)前升級(jí)包所支持的版本范圍:VERSION.mbn。
版本名稱格式:RK3568 QP1A.XXXXXX.{大版本號(hào)(6位)}.XXX{小版本號(hào)(3位)}。例如:RK3568 QP1A.190711.020。名稱中“190711”為大版本號(hào),“020”為小版本號(hào)。
配置例如下:
RK3568 QP1A.190711.001
1.4 創(chuàng)建“OTA.tag文件”,內(nèi)容為OTA升級(jí)包的魔數(shù),固定如下:
package_type:ota1234567890qwertw //可選
1.5 updater_binary二進(jìn)制文件
updater_binary該文件為系統(tǒng)編譯自動(dòng)生成,路徑:
out/rk3568/packages/phone/updater/bin/updater_binary
1.6 updater_specified_config.xml配置
head info OTA.tag vendor.img system.img
1.7 執(zhí)行升級(jí)包制作命令
python build_update.py ./target_package/ ./output_package/ -pk ./rsa_private_key2048.pem
?./target_package/:指定target_package路徑。
?./output_package/:指定升級(jí)包輸出路徑。
?-pk ./rsa_private_key3072.pem:指定私鑰文件路徑。
?此處可以使用系統(tǒng)自帶的證書(shū):device/board/hisilicon/hispark_taurus/linux/updater/config/rsa_private_key2048.pem注:OpenHarmony 3.2 Beta3分支上base/update/packaging_tools倉(cāng)制作updater升級(jí)包校驗(yàn)有BUG,會(huì)失敗。開(kāi)發(fā)者已經(jīng)在master分支上修復(fù),制作升級(jí)包前請(qǐng)同步master上最新代碼。
2.配置服務(wù)器
搭建搜包服務(wù)器(OTA搜包服務(wù)器采用OpenSSL協(xié)議傳輸數(shù)據(jù),所以必須使用HTTPS解析),服務(wù)器源碼見(jiàn)附件sslserver目錄。
3.配置網(wǎng)絡(luò)
3.1 配置客戶端服務(wù)器信息
為了方便調(diào)試,我們提供了本地可配置文件修改方案(patch見(jiàn)附件)。服務(wù)器搭建完成后,只需要在開(kāi)發(fā)板配置服務(wù)地址,搜包地址,端口號(hào)等信息即可完成搜包,下載等功能。
配置路徑:/system/etc/serverInfo.json
{
"serverIp": "115.126.57.xx", //服務(wù)器ip
"serverSearch": "115.126.57.xx", //搜包服務(wù)器
"serverPort":9556 //端口號(hào)
}
3.2 OpenHarmony 3.2 Beta3分支默認(rèn)route路由是關(guān)閉的,只要先打開(kāi)route才能連接外網(wǎng)。搜包前先要替換toybox文件,配置好的toybox已在附件中提供,直接通過(guò)hdc_std file send toybox(路徑) /system/bin/ 替換即可。
3.3 導(dǎo)入signing_cert.crt證書(shū)
hdc_std file send signing_cert.crt(路徑) /data/ota_package
3.4 配置路由地址
hdc_std shell
route add default gw 10.51.11.1 dev eth1 //10.51.11.1是網(wǎng)關(guān)地址,根據(jù)實(shí)際情況配置,如果不知道如何查看網(wǎng)關(guān),請(qǐng)聯(lián)系你們的網(wǎng)絡(luò)管理員。
ping www.huawei.com //ping確認(rèn)是否可以聯(lián)網(wǎng)
?
3.4 為了方便觀察效果,可通過(guò)hdc_std shell power-shell setmode 602命令,將屏幕設(shè)置為常亮。
?4. 升級(jí)客服端代碼實(shí)例
需要權(quán)限:
ohos.permission.UPDATE_SYSTEM和ohos.permission.INTERNET,系統(tǒng)權(quán)限需要使用FULL_SDK.
4.1 獲取在線升級(jí)對(duì)象
//調(diào)用方包名,若在設(shè)置中插入升級(jí),可添加為設(shè)置應(yīng)用的包名
const PACKAGE_NAME = "com.ohos.ota.updateclient";
let upgradeInfo = {
upgradeApp: PACKAGE_NAME,
businessType: {
vendor: "HZOS",
subType: 1
}
}
page.data.updater=client.getOnlineUpdater(upgradeInfo);
4.2 獲取版本信息
4.2.1 獲取升級(jí)任務(wù)信息
page.data.updater.getTaskInfo().then(taskInfo => { //...});//返回任務(wù)信息對(duì)象
4.2.2 檢查新版本信息
page.data.updater.checkNewVersion().then(data => {
//...
});//返回搜包結(jié)果對(duì)象
?
4.2.3 獲取新版本信息
page.data.updater.getNewVersionInfo().then(data => {
//...
});//返回新版本信息對(duì)象
?
4.3 版本下載
調(diào)用download(versionDigestInfo, downloadOptions) 下載新版本。
let versionDigestInfo = {
versionDigest: "versionDigest" // 檢測(cè)結(jié)果中的版本摘要信息
};
let downloadOptions = {
allowNetwork: 1,
order: 1
}
page.data.updater.download(versionDigestInfo, downloadOptions).then(result => {
console.info(TAG + "updater download result: " + JSON.stringify(result));
}).catch(error => {
console.error(TAG + "updater download error: " + JSON.stringify(error));
});
?
4.4 安裝新版本
調(diào)用upgrade(versionDigestInfo, upgradeOptions),安裝新版本,開(kāi)發(fā)板會(huì)重啟進(jìn)入系統(tǒng)升級(jí)頁(yè)面,待系統(tǒng)升級(jí)完成。
clickInstall: function () {
if (page.data.pageType == "downSuccess") { // 下載成功,開(kāi)始升級(jí)
page.upgrade();
}
},
upgrade() {
if (page.data.updater == undefined) {
//...
return;
}
page.data.updater.on(eventClassifyInfo, eventInfo => {
console.info(TAG + "upgrade eventInfo: " + JSON.stringify(eventInfo));
//...
});
let upgradeOptions = {
order: 2 //安裝
}
page.data.updater.upgrade(versionDigestInfo, upgradeOptions).then(result => {
console.info(TAG + "upgrade result: " + JSON.stringify(result));
}).catch(error => {
console.error(TAG + "upgrade error: " + JSON.stringify(error));
});
}
?
進(jìn)入updater模式,升級(jí)過(guò)程中會(huì)提示“正在更新 請(qǐng)勿重啟”。
?
?
升級(jí)完成后頁(yè)面會(huì)提示“升級(jí)完成”,之后重啟。
?
?
升級(jí)完成后,再次校驗(yàn)當(dāng)前版本信息,提示當(dāng)前已是最新版本。
?
?OTA升級(jí)調(diào)試
正常模式:在該路徑下data/updater/log獲取updater_log、updater_stage_log、error_code.log三份日志文件。 updater模式:在該路徑下tmp/獲取updater.log、updater_stage.log、error_code.log三份日志文件。 updater.log搜索關(guān)鍵字fail即可快速定位問(wèn)題。 ?總結(jié)
OpenHarmony OTA升級(jí)主要是搭建搜包服務(wù)器,制作升級(jí)包,了解OTA下載包管理,包解析,包管理的代碼邏輯。同時(shí),對(duì)于常見(jiàn)問(wèn)題知道如何快速定位!參考鏈接
升級(jí)客戶端應(yīng)用、服務(wù)器源碼https://gitee.com/wanfan_yyds/upgrade3.2
基于OpenHarmony 3.2 Beta3分支源碼的patchhttps://gitee.com/wanfan_yyds/update_updateservice/commit/44e28bb1d8d84b200348c5ad03f9f4ce3bad3e1e
https://gitee.com/wanfan_yyds/update_updater/commit/0fe02cec5b21bd3f9a47c4e5a0fd0e5790088703
參考文獻(xiàn)https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/application-dev/reference/apis/js-apis-update.md/
https://gitee.com/openharmony/update_updater
https://gitee.com/openharmony/update_updateservice
https://gitee.com/openharmony/update_update_app
https://gitee.com/openharmony/update_packaging_tools
原文標(biāo)題:如何實(shí)現(xiàn)OpenHarmony的OTA升級(jí)
文章出處:【微信公眾號(hào):OpenAtom OpenHarmony】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
-
鴻蒙
+關(guān)注
關(guān)注
57文章
2352瀏覽量
42863 -
OpenHarmony
+關(guān)注
關(guān)注
25文章
3722瀏覽量
16323
原文標(biāo)題:如何實(shí)現(xiàn)OpenHarmony的OTA升級(jí)
文章出處:【微信號(hào):gh_e4f28cfa3159,微信公眾號(hào):OpenAtom OpenHarmony】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論