Android項(xiàng)目升級(jí)之增量更新(版本迭代技術(shù))

一错沃,背景

在我們項(xiàng)目上架到各大應(yīng)用市場(chǎng)平臺(tái)后,這時(shí)我們的APP修改了一下bug后,這時(shí)一般我們需要重新上架新版本,或者在APP應(yīng)用內(nèi)從服務(wù)器下載新的APP,重新安裝APP,這叫 全量更新 . 全量更新有以下缺點(diǎn):
1,小功能或者小bug產(chǎn)品頻繁迭代.
2,服務(wù)器及客戶端下載耗流量.

比如:一個(gè)APP的V1.0.0版本的大小為20MB,現(xiàn)在需要發(fā)布V1.0.1版本的大小為22MB,我們對(duì)這兩個(gè)版本的apk文件差分對(duì)比,他們的差異包只有2Mb,如果我們使用增量更新這時(shí)只需要下載2MB,而全量更新就需要下載22MB大小的apk。

二睁冬,增量更新原理

增量更新圖.png

1、增量更新主要分為兩步:
1)服務(wù)端拿新版本A和舊版本B做差分驾荣,生成差分包C‘
2)客戶端檢測(cè)到可增量更新的差分包摸屠,下載差分包C‘之后,和本地舊版本B做合成描函,生成新版本A。

image.png

2狐粱、步驟詳細(xì)展開:

服務(wù)器端:服務(wù)端的同學(xué)拿到客戶端同學(xué)開發(fā)的新版本A舀寓,跟已發(fā)布的舊版本B1,B2肌蜻,B3...做了差分生成相應(yīng)的差分包C1互墓,C2,C3...蒋搜,并生成相應(yīng)差分包的MD5值篡撵,當(dāng)然全量包的簽名、MD5值也是需要的豆挽,這樣客戶端需要的所有數(shù)據(jù)就OK了育谬。

客戶端:用戶手動(dòng)更新或程序主動(dòng)請(qǐng)求檢測(cè)更新:
1)客戶端用MD5值和版本號(hào)作為參數(shù)向服務(wù)端請(qǐng)求更新數(shù)據(jù),若服務(wù)端沒有差分包則返回全量包下載URL帮哈、MD5值膛檀、簽名值。
2)若服務(wù)端存在相應(yīng)的差分包則返回差分包下載URL娘侍,全量包簽名值咖刃、全量包和差分包MD5值,全量包簽名值和MD5值憾筏。把差分包下載到本地之后(C1)嚎杨,先做MD5值校驗(yàn),確保下載的差分包數(shù)據(jù)的完整性氧腰,校驗(yàn)失敗則走全量更新邏輯磕潮,校驗(yàn)無誤和本地現(xiàn)有安裝的舊版本(B1)進(jìn)行差分合并生成新版本(A),之后進(jìn)行合成版本的MD5值校驗(yàn)和簽名校驗(yàn)容贝,確保合成文件的完整性和簽名信息的正確性。校驗(yàn)無誤進(jìn)行安裝之景。

3斤富、需要考慮的一些問題:

1)服務(wù)端生成的差分包大小接近新包大小,或者直接超過新包大小锻狗,就沒必要進(jìn)行差分更新满力;

2)下載到本地之后是否需要進(jìn)行簽名校驗(yàn)依賴各自情況焕参,若有和系統(tǒng)方進(jìn)行合作的,系統(tǒng)方一般會(huì)拿APK進(jìn)行二次簽名之后作為系統(tǒng)內(nèi)置應(yīng)用油额。

3)下載文件當(dāng)然也需要支持?jǐn)帱c(diǎn)續(xù)傳叠纷,考慮再細(xì)點(diǎn),下載APK的過程中有可能被劫持或者被運(yùn)營(yíng)商重定向潦嘶,如果是全量更新下載涩嚣,可以和服務(wù)端約定每段下載數(shù)據(jù)的校驗(yàn)邏輯規(guī)則,在HTTP頭中附加校驗(yàn)字段數(shù)據(jù)掂僵,確保萬無一失航厚;

4)服務(wù)端是否根據(jù)客戶端的更新請(qǐng)求實(shí)時(shí)生成差分?jǐn)?shù)據(jù)?從目前生成差分包的測(cè)試數(shù)據(jù)來看锰蓬,這個(gè)實(shí)現(xiàn)是不靠譜的幔睬。最好就是有新版本之后,在服務(wù)端先把差分包數(shù)據(jù)準(zhǔn)備好芹扭,而不是等到請(qǐng)求更新的時(shí)候再生成差分包麻顶。

原著來自:http://www.reibang.com/p/6cda8fd3464a

三,BSDiff/BSPatch舱卡、HPatch辅肾、XDelta工具測(cè)試數(shù)據(jù)對(duì)比

差分包工具對(duì)比.png

四,Android 增量更新的完整實(shí)現(xiàn)步驟

轉(zhuǎn)載: http://www.reibang.com/p/f1f9d1c8bb4e

五灼狰,PC端生成差分包步驟

1宛瞄, 準(zhǔn)備工具
開源框架:http://www.daemonology.net/bsdiff/
依賴bzip2庫:https://sourceforge.net/projects/gnuwin32/files/bzip2/

下載后的工具:(有需要可聯(lián)系我發(fā)給你們)


客戶端生成差分包工具.png
BSDiff核心思想.png

2, 解壓bsdiff-v4.3-win-x64.zip ,在當(dāng)前文件夾輸入一下命令生成差異包patch.


TIM圖片20190226162815.png

六, Android端實(shí)現(xiàn)合成

1, 創(chuàng)建一個(gè)NDK的AS項(xiàng)目,如果你原有的項(xiàng)目沒有NDK文件,可以把新創(chuàng)建的NDK項(xiàng)目把以下文件拷貝到老項(xiàng)目中.

image.png

在build.gradle中添加:

  externalNativeBuild {
            cmake {
                cppFlags ""
            }
        }

  externalNativeBuild {
        cmake {
            path "CMakeLists.txt"
        }
    }

參考: https://blog.csdn.net/qq_34106574/article/details/84298944

2,執(zhí)行bsPath合成

image.png
image.png
image.png
image.png
image.png
image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市交胚,隨后出現(xiàn)的幾起案子份汗,更是在濱河造成了極大的恐慌,老刑警劉巖蝴簇,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件杯活,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡熬词,警方通過查閱死者的電腦和手機(jī)旁钧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來互拾,“玉大人歪今,你說我怎么就攤上這事⊙湛螅” “怎么了寄猩?”我有些...
    開封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)骑疆。 經(jīng)常有香客問我田篇,道長(zhǎng)替废,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任泊柬,我火速辦了婚禮椎镣,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘兽赁。我一直安慰自己状答,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開白布闸氮。 她就那樣靜靜地躺著剪况,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蒲跨。 梳的紋絲不亂的頭發(fā)上译断,一...
    開封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音或悲,去河邊找鬼孙咪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛巡语,可吹牛的內(nèi)容都是我干的翎蹈。 我是一名探鬼主播,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼男公,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼荤堪!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起枢赔,我...
    開封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤澄阳,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后踏拜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體碎赢,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年速梗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了肮塞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡姻锁,死狀恐怖枕赵,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情位隶,我是刑警寧澤烁设,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響装黑,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜弓熏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一恋谭、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧挽鞠,春花似錦疚颊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至嫁赏,卻和暖如春其掂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背潦蝇。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工款熬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人攘乒。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓贤牛,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親则酝。 傳聞我的和親對(duì)象是個(gè)殘疾皇子殉簸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容