摘要: 支付寶從最開始的工具型應用,逐漸發展成平臺型應用,一直到如今,已經成爲了一個超級 App。本文將帶領你們進一步瞭解支付寶在動態化方案的探索以及 Nebula 框架。
小螞蟻說:web
此前分享的《模塊化與解耦式開發在螞蟻金服mPaaS深度實踐探討》(想要了解更多相關內容,歡迎關注公衆號:mPaaS )已經對支付寶在移動端開發架構的設計思路有了初步瞭解。本文將結合在 iWeb 武漢站的分享,帶領你們進一步瞭解 mPaaS 在移動端動態化方案設計。小程序
分享內容將分爲如下三個方面:api
任何一種技術方案都是在業務的發展和架構的演化中逐漸探索出來的,所以咱們來看一下支付寶架構的演進: 瀏覽器
支付寶從最開始的工具型應用,逐漸發展成平臺型應用,一直到如今,已經成爲了一個超級 App,它擁有多應用的生態,更加開放和動態化,而且保持着高可用,高性能,高靈敏的強大特性。隨着 App 的逐漸龐大,整個應用的架構也在進行不斷的調整,來適應各類特性。如今的支付寶客戶端的架構如圖所示: 安全
總體架構分爲五層:容器層、組件層、框架層、服務層、應用層。網絡
客戶端總體採用統一的框架開發,模塊化的開發模式,徹底插件式的容器,支持模塊獨立發佈,方便大規模團隊的並行開發。數據結構
在這樣的框架結構中,一樣包括了咱們的動態化方案。支付寶中的動態化方案主要有兩種框架:Nebula 和小程序。架構
這兩種方案不只解決了需求迭代速度和發版週期之間的矛盾、跨平臺開發、實時發佈等一些普適問題,並且有效地保證了發佈質量,對線上問題進行緊急止血,同時也有助於創建良好的開放生態。併發
Nebula 是支付寶移動端 Hybrid 解決方案,它提供了良好的外部擴展功能,擁有功能插件化、事件機制、JSApi 定製和 H5App 推送更新管理能力。app
主要功能包括:
還有一種動態化方案就是支付寶小程序:
支付寶小程序是一種全新的開發模式,融合了 H5 的易開發性、跨平臺性、Native 性能,讓開發者能夠快速開發高性能的頁面,提供優異的用戶體驗。經過使用支付寶小程序,開發者爲支付寶開發了大量優質的小程序,豐富了支付寶生態能力。小程序開放給開發者更多的 JSAPI 和 OpenAPI 能力,經過小程序能夠爲用戶提供多樣化便捷服務。
Nebula 的架構如圖所示,從上至下依次爲 H5 應用層、服務層、原生框架層:
H5 應用層:基於 HTML 和 JavaScript 技術開發,在 H5 容器上運行的手機應用,它擁有跨平臺的特性,配合離線包的使用能夠完成實時熱修復的功能。
服務層:爲開發者提供了高階語言的 API 來使用手機系統資源,包括:
原生框架層:是手機系統的基礎層,它提供了標準 API 來讓高階語言(好比 Java 和 Object-C)使用底層的硬件,幷包含了許多爲硬件訪問的專有軟件庫。當上層調用某個框架 API 來訪問硬件時,手機系統將加載相應的軟件庫。
整個 Nebula 框架的核心部分就是 H5 容器,下面看一下 H5 容器的結構:
H5Service,H5Session 和 H5Page都是從 H5CoreNode 類擴展而來,以 H5Service 爲根節點,它與其餘類一同造成了樹狀結構構成了頁面流程和導航。在通常狀況下,H5Pages 是 H5Session 的子節點,而 H5Sessions 是 H5Service 的子節點,在任何狀況下只有一個 H5Service 根節點存在。
H5Service:是 Nebula 裏維護 H5 應用全局狀態的基礎類, 在 H5 應用的生命週期內只有一個 H5Service 的單例全局實例,H5Service 能夠進行的操做包括:
H5Session:一個 H5Session 是由一疊 H5Pages 組成的完整業務流程。例如一個收銀臺的流程包括:一個購物車的小結頁面,一個結帳方式的選擇頁面,和最後一個結帳確認頁面。全部的頁面均可以獨立存在運做, H5Session 在其中的做用是把這些頁面組織起立,按照業務邏輯把它們按序排列來完成業務。當你使用 H5Service 建立且開啓一個新的 Web page 時,若是當前沒有 H5Session 的話,一個新的 H5Session 實例將被建立,併爲後續建立的 Web page 共享。你能夠從 H5Session 中移除頁面直到頁面疊爲空,也可使用 H5Session 所提供的方法來獲取首頁,以及監聽該 H5Session 的生命週期。
H5Page:是用戶看得見,摸得着的頁面,也是應用生命週期中最重要的一部分。你能夠經過 URL 來加載內容,用 H5Param 來定製頁面的外觀和行爲,甚至能夠經過獲取 H5Page 的視圖層次,把 H5Page 視圖和其餘原生 UI 部件一塊兒內嵌到同一個佈局中。
下面是 H5 容器的幾個重要組成部分:
JS Bridge 是鏈接原生層和 Javascript 的溝通橋樑:它將 Javascript 代碼轉譯成能在系統框架運行的字節碼,同時也把原生層的數據結構轉成 Javascript 對象使其能在 Javascript 層處理。這裏 Nebula 針對JS Bridge 作了一些優化:
使用 prompt 會阻斷整個瀏覽器的進程,若是 native 處理時間一長,會致使頁面假死。
如今在支付寶內使用的方式爲監聽 H5 生活週期的事件,好比說當 Webview 設置 title 結束以後,Android 會放出一個 onReceivedTitle、shouldInterceptRequest 等事件,iOS 會嘗試在 webViewDidStartLoad 事件,在監聽到這些事件以後,當即注入 bridgejs,讓其在 H5 生命週期儘早運行。經過這種方式的注入,通過測試,最先能在頁面加載開始後, 50ms 之內就能成功注入 bridgejs。
這個步驟中事件派遣的順序爲 H5Service -> H5Session or H5Page。
事件能夠在任何節點被攔截 (若是 interceptEvent() 返回 true ),也能夠在任何節點被處理 (若是 handleEvent() 返回 true ):若是事件在派遣過程當中被攔截或處理,該事件將被視爲已被消費且再也不繼續流通。若是在派遣過程後事件依舊沒有被攔截或處理,會有錯誤拋給呼叫方處理。
僅僅使用傳統的 H5 技術展現在線頁面,很容易受到網絡環境影響,於是下降 H5 頁面的性能。
在 Neblua 中咱們使用離線包技術來解決這個問題。離線包是將包括 HTML、Javascript、CSS 等頁面內靜態資源打包到一個壓縮包內,它的目錄結構如圖所示:
使用離線包可使容器內的 H5 應用具備接近 Native 的體驗,主要優點以下:
下面介紹一下離線包的渲染過程當 H5 容器發出資源請求時,其訪問本地資源或線上資源所使用的 URL 是一致的。H5 容器會先截獲該請求,截獲請求後,發生以下狀況:
離線包的下載依賴用戶當前的網絡。通常狀況下,只有在鏈接 WIFI 的狀況下才會在後臺下載離線包。若是用戶處於移動網絡下,不會在後臺下載離線包。若是當前用戶點擊 APP,離線包沒有下載好,用戶就要等待離線包下載好才能用。
爲了解決離線包不可用的場景,fallback 技術應運而生。每一個離線包發佈的時候,都會同步在 CDN 發佈一個對應的線上版本,目錄結構和離線包結構一致。fallback 地址會隨離線包信息下發到本地。在離線包沒有下載好的場景下,客戶端會攔截頁面請求,轉向對應的 CDN 地址, 實如今線頁面和離線頁面隨時切換。
那麼本地資源如何尋址呢,咱們設計了獨特的虛擬域名機制,僅對離線應用有效。當頁面保存在客戶端以後,WebView 若是要訪問的話,是經過 file schema 來從本地加載訪問的。然而,用戶就能在地址欄裏直接看到 file 的路徑,這就會致使如下問題:
Nebula 裏面的 H5 容器和離線包,在傳統的 Hybrid 框架的基礎上進行了極致的優化,使整個 H5 應用具備以下特色:
在性能方面,Nebula 在支付寶中通過了億級用戶的考驗,crash 和 anr 以及其餘穩定性指標有保障。Android 平臺基於 UCWebview 深度定製,crash 率和 anr 量遠低於系統webview,擁有解決系統 Webview 問題的能力。圖中展現的就是在 Android 端,UCWebview 和系統 Webview 之間崩潰率和 ANR 率的對比,穩定性的優點顯而易見。
最後看一下小程序與 Nebula支付寶小程序複用 Nebula 容器技術棧,重構了開發方式,對外暴露有限個 jsapi 接口,讓 app 開發更簡單,更加便捷利用支付寶的能力,進而發佈、推廣、運營。小程序本質上是也是一個 H5 App 離線包,可是有一些本身的特色。
Nebula 有這麼大優點,如今不只在螞蟻金服內部使用,也可以提供給外部來使用。
首先什麼是 mPaaS 呢,mPaaS 全稱是 Mobile Platform as a Service 。是螞蟻金服首創的移動研發平臺,它源於支付寶 App 近 10 年的移動技術實踐和思考,爲移動開發、測試、運營及運維提供雲到端的一站式解決方案,能有效下降技術門檻、減小研發成本、提高開發效率,協助生態夥伴快速搭建穩定高質量的移動 App。
在 mPaaS 中,咱們將 Nebula 的 H5 容器、jsapi 、離線包、小程序這些模塊做爲一個單獨的組件來進行輸出,在客戶端中進行配置。任何一個 App 經過 mPaaS 插件,添加對應的模塊,集成這些功能,只須要這樣簡單的操做,就可讓你的應用具備和支付寶同樣強大的動態化能力。
同時 mPaaS 提供的小程序模塊,容許用戶把運行在支付寶上的小程序,無縫的遷移到本身的 App 中,作到【跨平臺跨應用】開發,提升代碼的複用能力Nebula 組件化輸出,配合 mPaaS 提供的 MDS (移動發佈服務) 來實現動態更新。
mPaaS 提供的 MDS 服務,可以讓每次發佈更新就像發郵件同樣簡單。
MDS 具備智能灰度發佈的能力,能夠經過內部灰度,外部灰度多重驗證,保證在正式發佈以前,發佈的產品質量有充分的保證,同時提供多種升級策略,包括指定人羣地域、機型,系統版本,網絡環境等多種規則。對於離線包來講,更新離線包的下載對網絡環境要求較高,包的大小越大,更新的成功率越低,在 mPaaS 中,咱們採用增量差分的更新能力,減小數據冗餘及設備帶寬,在移動網絡條件下優點明顯。同時保證更新功能的高可用性,升級接口可用率達 99.99%,在線分鐘級觸達。
下面是 Nebula 的生態基礎,首先在集團內部,咱們已經支持了很多產品,同時經過 mPaaS ,咱們也與外部客戶合做,將咱們的技術能力輸出給他們,典型的幾個案例,包括 12306 客戶端,廣發發現精彩客戶端,上海地鐵,蘇州銀行等。
尤爲是 12306,使用 mPaaS 改版以後,客戶端總體的體驗更加優越。12306 整個客戶端絕大部分都是使用的 H5 技術,他們就是使用 Nebula H5 容器 配合離線包來實現,不管是頁面打開速度,仍是UI事件響應,體驗幾乎接近 native。在更新發布方面,12306 的 app 包不多更新,以 AppStore 上的發佈記錄來看,今年只提交了兩個版本,基本上都是經過動態化的方式完成業務的迭代發佈。
總結下來,螞蟻金服 mPaaS 中就是經過「Nebula H5容器 + 離線包 + 小程序 + MDS」這樣的方式來實現移動端的動態化方案。
本文爲雲棲社區原創內容,未經容許不得轉載。