微信Android熱更新Tinker使用詳解(星空武哥)
Tinker是什么
Tinker是微信官方的Android熱補丁解決方案,它支持動態(tài)下發(fā)代碼、So庫以及資源,讓應(yīng)用能夠在不需要重新安裝的情況下實現(xiàn)更新。當(dāng)然,你也可以使用Tinker來更新你的插件。
它主要包括以下幾個部分:
gradle編譯插件: tinker-patch-gradle-plugin
核心sdk庫: tinker-android-lib
非gradle編譯用戶的命令行版本: tinker-patch-cli.jar
為什么使用Tinker
當(dāng)前市面的熱補丁方案有很多,其中比較出名的有阿里的AndFix、美團的Robust以及QZone的超級補丁方案。但它們都存在無法解決的問題,這也是正是我們推出Tinker的原因。
總的來說:
AndFix作為native解決方案,首先面臨的是穩(wěn)定性與兼容性問題,更重要的是它無法實現(xiàn)類替換,它是需要大量額外的開發(fā)成本的;
Robust兼容性與成功率較高,但是它與AndFix一樣,無法新增變量與類只能用做的bugFix方案;
Qzone方案可以做到發(fā)布產(chǎn)品功能,但是它主要問題是插樁帶來Dalvik的性能問題,以及為了解決Art下內(nèi)存地址問題而導(dǎo)致補丁包急速增大的。
特別是在android N之后,由于混合編譯的inline策略修改,對于市面上的各種方案都不太容易解決。而Tinker熱補丁方案不僅支持類、So以及資源的替換,它還是2.X-7.X的全平臺支持。利用Tinker我們不僅可以用做bugfix,甚至可以替代功能的發(fā)布。Tinker已運行在微信的數(shù)億Android設(shè)備上,那么為什么你不使用Tinker呢?
Tinker的已知問題
由于原理與系統(tǒng)限制,Tinker有以下已知問題:
Tinker不支持修改AndroidManifest.xml,Tinker不支持新增四大組件;
由于Google Play的開發(fā)者條款限制,不建議在GP渠道動態(tài)更新代碼;
在Android N上,補丁對應(yīng)用啟動時間有輕微的影響;
不支持部分三星android-21機型,加載補丁時會主動拋出"TinkerRuntimeException:checkDexInstall failed";
由于各個廠商的加固實現(xiàn)并不一致,在1.7.6以及之后的版本,tinker不再支持加固的動態(tài)更新;
對于資源替換,不支持修改remoteView。例如transition動畫,notification icon以及桌面圖標。
如何使用Tinker
下面就一BuglyTinker的使用方式進行介紹
為什么使用Bugly熱更新?
因為bugly已經(jīng)集成了tinker
無需關(guān)注Tinker是如何合成補丁的
無需自己搭建補丁管理后臺
無需考慮后臺下發(fā)補丁策略的任何事情
無需考慮補丁下載合成的時機,處理后臺下發(fā)的策略
我們提供了更加方便集成Tinker的方式
我們通過HTTPS及簽名校驗等機制保障補丁下發(fā)的安全性
豐富的下發(fā)維度控制,有效控制補丁影響范圍
我們提供了應(yīng)用升級一站式解決方案
至于如何使用Bugly熱更新看文檔就可以了,今天我就說一說官網(wǎng)文檔中多渠道補丁的一些錯誤(今天以Bugly1.2.2(tinker1.7.6))為例
在project的build.gradle中添加依賴
配置app build.gradle
這里要注意,官方給出的project.tinkerPatch.oldApk、project.tinkerPatch.buildConfig.applyMapping、project.tinkerPatch.buildConfig.applyResourceMapping三個配置路徑有錯誤,tinker 1.7.6也存在多渠道打包有bug(和官方溝通后證實了這一點)
我們在進行多渠道打包的時候會執(zhí)行下面的命令,他打出的補丁包都是一樣的,通過查看補丁包內(nèi)的YAPATCH.MF文件就可以證明,官網(wǎng)表示會在下一個版本中修復(fù)
這里的簽名方式不懂可以看這篇文章:http://chabaoo.cn/article/122745.htm
這里的配置的config.gradle不明白可以看這篇文章:http://chabaoo.cn/article/122746.htm
tinker-support.gradle的配置,
配置config.gradle
其他配置
不要忘了混淆,還有關(guān)于適配Android7.0系統(tǒng)的配置,這里就不說了。
接下來我們執(zhí)行下面的命令開始生成基準包(一定要保留好基準包)
tinkerPatchAllFlavorRelease
生成生產(chǎn)版本的apk后,如果我們發(fā)現(xiàn)bug,可以修復(fù)bug,然后生成補丁包。
生成完補丁包后,就可以借助Bugly的熱更新進行修復(fù)了,找到我們注冊的app,上傳補丁包
tinker是在我們打開app的時候去檢查服務(wù)器有沒有補丁包,以及本地有沒有補丁包,如果檢測到了就去下載,然后會在下次啟動app的進行補丁的修復(fù)。這樣通過Bugly我們不用去搭建下發(fā)補丁包的服務(wù)器了,特別方便。
源代碼代碼:BuglyTinker_jb51.zip
相關(guān)文章
Android 出現(xiàn)“Can''t bind to local 8602 for debugger”錯誤的解決方法
這篇文章主要介紹了Android 出現(xiàn)“Can't bind to local 8602 for debugger”錯誤的解決方法的相關(guān)資料,需要的朋友可以參考下2017-03-03Android 使用Vitamio打造自己的萬能播放器(5)——在線播放(播放優(yōu)酷視頻)
本文主要介紹Android Vitamio的使用,這里給大家提供效果圖和代碼實例,來說明Vitamio組件播放網(wǎng)絡(luò)視頻,有需要的小伙伴可以參考下2016-07-07android4.0混淆XmlPullParser報錯原因分析解決
今天,用android4.0在proguard-project.txt中加入 -libraryjars libs/ksoap2-android-assembly-2.6.0-jar-with-dependencies.jar這句話后,混淆時報上面的錯誤,下面與大家分享下具體的解決方法2013-06-06Android完美實現(xiàn)平滑過渡的ViewPager廣告條
這篇文章主要為大家詳細介紹了Android完美實現(xiàn)平滑過渡的ViewPager廣告條,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11