手機(jī)淘寶客戶端架構(gòu)探索-宗心_第1頁(yè)
手機(jī)淘寶客戶端架構(gòu)探索-宗心_第2頁(yè)
手機(jī)淘寶客戶端架構(gòu)探索-宗心_第3頁(yè)
手機(jī)淘寶客戶端架構(gòu)探索-宗心_第4頁(yè)
手機(jī)淘寶客戶端架構(gòu)探索-宗心_第5頁(yè)
已閱讀5頁(yè),還剩14頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、手機(jī)淘寶客戶端架構(gòu)探索實(shí)踐關(guān)于于佳(宗心)2011 : 阿里巴巴中文站 阿里巴巴手機(jī)客戶端 android/iOS 開(kāi)發(fā)2012:阿里巴巴無(wú)線事業(yè)部 手機(jī)淘寶客戶端 iOS 開(kāi)發(fā)阿里巴巴無(wú)線事業(yè)部負(fù)責(zé)手機(jī)淘寶并為阿里巴巴各條無(wú)線產(chǎn)品線提供基礎(chǔ)技術(shù)和設(shè)施發(fā)展歷程201020122013Android: 披著App外衣的Mobile WebiOS: 圍繞購(gòu)物主鏈路的基本功能業(yè)務(wù):?jiǎn)喂こ潭喾种ч_(kāi)發(fā)底層:獨(dú)立的中間件工程Android:Atlas插件框架iOS:多工程插件化開(kāi)發(fā)1.02.03.0產(chǎn)品挑戰(zhàn)承載并整合多樣化的業(yè)務(wù)生態(tài)研發(fā)挑戰(zhàn) 去年All-In的時(shí)候 大量業(yè)務(wù)的同時(shí)涌入 火車模型的懸崖效應(yīng)

2、10余個(gè)團(tuán)隊(duì)的代碼整合量變呼喚質(zhì)變!痛點(diǎn) 協(xié)同方式 迭代依賴 分支管理合并依賴關(guān)系過(guò)于復(fù)雜! 調(diào)試自測(cè)效率 模塊依賴下的不穩(wěn)定因素 業(yè)務(wù)多,回歸成本大測(cè)試資源嚴(yán)重不足!其他模塊引起的不穩(wěn)定性因素 發(fā)布的靈活性 版本發(fā)布無(wú)法快速響應(yīng) 線上已發(fā)布版本穩(wěn)定性灰度以及線上版本crash難以修復(fù)!2014手機(jī)淘寶自誕生以來(lái),最大規(guī)模的底層重構(gòu)改變:開(kāi)發(fā)方式,工程結(jié)構(gòu),架構(gòu)模型,打包方式探索新的路線圍繞著開(kāi)發(fā)效率和性能穩(wěn)定性等一系列問(wèn)題工程拆分支持多團(tuán)隊(duì)并行開(kāi)發(fā)架構(gòu)重構(gòu)重新梳理容器和總線規(guī)則配套工具使用有力工具增加開(kāi)發(fā)效率工程拆分并行開(kāi)發(fā)業(yè)務(wù)解耦獨(dú)立調(diào)試集成之前,在穩(wěn)定環(huán)境下測(cè)試易于集成修改配置完成集成工

3、程拆分開(kāi)發(fā)階段 提供穩(wěn)定的開(kāi)發(fā)環(huán)境(底層庫(kù),接口) 各個(gè)業(yè)務(wù)方獨(dú)立開(kāi)發(fā)測(cè)試階段 單獨(dú)業(yè)務(wù)獨(dú)立打包 針對(duì)該業(yè)務(wù)的測(cè)試回歸集成階段 修改podfile進(jìn)行集成測(cè)試 針對(duì)整體流程做回歸架構(gòu)重構(gòu) 需要解決的問(wèn)題 迭代開(kāi)發(fā),并行開(kāi)發(fā)能力差。 耦合嚴(yán)重,核心功能(URL導(dǎo)航)復(fù)雜 試錯(cuò)成本過(guò)高,增加減少業(yè)務(wù)帶來(lái)的成本。 快速迭代下的穩(wěn)定性問(wèn)題。指導(dǎo)思想分而治之并行開(kāi)發(fā)一切皆組件BundleApp解除耦合,制定標(biāo)準(zhǔn)總線 URL總線(跨平臺(tái)統(tǒng)一URL尋址方式):三平臺(tái)統(tǒng)一URL,自動(dòng)降級(jí),中心分發(fā)(支持hook) 服務(wù)總線 :根據(jù)服務(wù)接口提供穩(wěn)定服務(wù) 消息總線 :中心分發(fā),按需加載開(kāi)發(fā)透明 只需要遵守規(guī)則,不

4、關(guān)心底層/其他業(yè)務(wù)實(shí)現(xiàn)Bundle (deployable unit)RuntimeBus (UI & Service & Message)Lifecycle ManagementBundle ManagementUIsServicesApp/Service ProjectRuntimeProjectBus LibraryLibrariesLibraries減少新業(yè)務(wù)接入/移除成本標(biāo)準(zhǔn)化統(tǒng)一的通信調(diào)用標(biāo)準(zhǔn),bundle間互通的基礎(chǔ)無(wú)法回避的瘦身問(wèn)題靈活性Bundle自由組裝(淘寶生活,碼上淘)中間件基礎(chǔ)庫(kù)自由引入及時(shí)響應(yīng)線上問(wèn)題Move fast and break thing

5、svia Hot Patch線上嚴(yán)重問(wèn)題快速修復(fù)(小時(shí)級(jí)的響應(yīng)時(shí)間)AOP編碼形式Before/After/Replace 某個(gè)方法編寫容易,發(fā)布規(guī)范配套工具工程拆分遇到的問(wèn)題:頻繁的更換spec源碼引入造成的pod update緩慢等原因開(kāi)發(fā)階段集成階段等問(wèn)題工具解決摩天輪自動(dòng)打包平臺(tái)(自動(dòng)生成spec,framework引入)開(kāi)發(fā)-集成-灰度,多階段管理其他工具解決的問(wèn)題:核心鏈路性能監(jiān)控平臺(tái)Crash分析平臺(tái)耗時(shí)2個(gè)月完成 6月初上線以上 集成 Bundle:30+ 改造為服務(wù):10+(登錄、緩存、搜索組件) Hot Patch 修復(fù)線上嚴(yán)重故障 10+ 起 Patch 最大6KB,大部分不到1KB(iOS) 最大的陣痛:底層依賴遷移引起的編譯失敗Bundle重組,互通有無(wú)。業(yè)務(wù)復(fù)用,減少人力基礎(chǔ)復(fù)用,做深做精敏捷開(kāi)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論