移動(dòng)端開發(fā)的網(wǎng)絡(luò)優(yōu)化

感謝作者:Trinea?

轉(zhuǎn)載于:http://b.codekk.com/blogs/detail/55538870d6459ae793499533

介紹下針對(duì)移動(dòng)端的網(wǎng)絡(luò)優(yōu)化,不限于 Android,同樣適用于 iOS 和 H5。這篇文章首發(fā)在微信公眾號(hào)codekk

一個(gè)網(wǎng)絡(luò)請(qǐng)求可以簡(jiǎn)單分為連接服務(wù)器 -> 獲取數(shù)據(jù)兩個(gè)部分。

其中連接服務(wù)器前還包括 DNS 解析的過程;獲取數(shù)據(jù)后可能會(huì)對(duì)數(shù)據(jù)進(jìn)行緩存。

一、連接服務(wù)器優(yōu)化策略

1. 不用域名,用 IP 直連

省去 DNS 解析過程,DNS 全名 Domain Name System,解析意指根據(jù)域名得到其對(duì)應(yīng)的 IP 地址。

如 www.codekk.com 的域名解析結(jié)果就是 104.236.147.76。

首次域名解析一般需要幾百毫秒,可通過直接向 IP 而非域名請(qǐng)求,節(jié)省掉這部分時(shí)間,同時(shí)可以預(yù)防域名劫持等帶來的風(fēng)險(xiǎn)。

當(dāng)然為了安全和擴(kuò)展考慮,這個(gè) IP 可能是一個(gè)動(dòng)態(tài)更新的 IP 列表,并在 IP 不可用情況下通過域名訪問。

2. 服務(wù)器合理部署

服務(wù)器多運(yùn)營商多地部署,一般至少含三大運(yùn)營商、南中北三地部署。

配合上面說到的動(dòng)態(tài) IP 列表,支持優(yōu)先級(jí),每次根據(jù)地域、網(wǎng)絡(luò)類型等選擇最優(yōu)的服務(wù)器 IP 進(jìn)行連接。

對(duì)于服務(wù)器端還可以調(diào)優(yōu)服務(wù)器的 TCP 擁塞窗口大小、重傳超時(shí)時(shí)間(RTO)、最大傳輸單元(MTU)等。

二、獲取數(shù)據(jù)優(yōu)化策略

1. 連接復(fù)用

節(jié)省連接建立時(shí)間,如開啟 keep-alive。

對(duì)于 Android 來說默認(rèn)情況下 HttpURLConnection 和 HttpClient 都開啟了 keep-alive。只是 2.2 之前 HttpURLConnection 存在影響連接池的 Bug,具體可見:Android HttpURLConnection 及 HttpClient 選擇

2. 請(qǐng)求合并

即將多個(gè)請(qǐng)求合并為一個(gè)進(jìn)行請(qǐng)求,比較常見的就是網(wǎng)頁中的 CSS Image Sprites。

如果某個(gè)頁面內(nèi)請(qǐng)求過多,也可以考慮做一定的請(qǐng)求合并。

3. 減小請(qǐng)求數(shù)據(jù)大小

(1) 對(duì)于 POST 請(qǐng)求,Body 可以做 Gzip 壓縮,如日志。

(2) 對(duì)請(qǐng)求頭進(jìn)行壓縮

這個(gè) Http 1.1 不支持,SPDY 及 Http 2.0 支持。

Http 1.1 可以通過服務(wù)端對(duì)前一個(gè)請(qǐng)求的請(qǐng)求頭進(jìn)行緩存,后面相同請(qǐng)求頭用 md5 之類的 id 來表示即可。

4. CDN 緩存靜態(tài)資源

緩存常見的圖片、JS、CSS 等靜態(tài)資源。

5. 減小返回?cái)?shù)據(jù)大小

(1) 壓縮

一般 API 數(shù)據(jù)使用 Gzip 壓縮,下圖是之前測(cè)試的 Gzip 壓縮前后對(duì)比圖。

(2) 精簡(jiǎn)數(shù)據(jù)格式

如 JSON 代替 XML,WebP 代替其他圖片格式,關(guān)注微信公眾號(hào)codeKK,回復(fù)20查看關(guān)于 WebP 的介紹。

(3) 對(duì)于不同的設(shè)備不同網(wǎng)絡(luò)返回不同的內(nèi)容

如不同分辨率圖片大小。

(4) 增量更新

需要數(shù)據(jù)更新時(shí),可考慮增量更新。如常見的服務(wù)端進(jìn)行 bsdiff,客戶端進(jìn)行 bspatch。

(5) 大文件下載

支持?jǐn)帱c(diǎn)續(xù)傳,并緩存 Http Resonse 的 ETag 標(biāo)識(shí),下次請(qǐng)求時(shí)帶上,從而確定是否數(shù)據(jù)改變過,未改變則直接返回 304。

6. 數(shù)據(jù)緩存

緩存獲取到的數(shù)據(jù),在一定的有效時(shí)間內(nèi)再次請(qǐng)求可以直接從緩存讀取數(shù)據(jù)。

關(guān)于 Http 緩存規(guī)則 Grumoon 在Volley 源碼解析最后雜談中有詳細(xì)介紹。

三、其他優(yōu)化手段

這類優(yōu)化方式在性能優(yōu)化系列總篇中已經(jīng)有過完整介紹

1. 預(yù)取

包括預(yù)連接、預(yù)取數(shù)據(jù)。

2. 分優(yōu)先級(jí)、延遲部分請(qǐng)求

將不重要的請(qǐng)求延遲,這樣既可以削峰減少并發(fā)、又可以和后面類似的請(qǐng)求做合并。

3. 多連接

對(duì)于較大文件,如大圖片、文件下載可考慮多連接。

需要控制請(qǐng)求的最大并發(fā)量,畢竟移動(dòng)端網(wǎng)絡(luò)受限。

四、監(jiān)控

優(yōu)化需要通過數(shù)據(jù)對(duì)比才能看出效果,所以監(jiān)控系統(tǒng)必不可少,通過前后端的數(shù)據(jù)監(jiān)控確定調(diào)優(yōu)效果。

注:服務(wù)器部署方面的優(yōu)化有參考手 Q 和 QZone 去年的技術(shù)分享。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,321評(píng)論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,559評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,442評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,835評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,581評(píng)論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,922評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,931評(píng)論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,096評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,639評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,374評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,591評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,104評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,789評(píng)論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,196評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,524評(píng)論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,322評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,554評(píng)論 2 379

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,826評(píng)論 18 139
  • 14.1 引言 域名系統(tǒng)(DNS)是一種用于TCP/IP應(yīng)用程序的分布式數(shù)據(jù)庫,它提供主機(jī)名字和IP地址之間的轉(zhuǎn)換...
    張芳濤閱讀 1,912評(píng)論 0 8
  • 最近,終于要把《WEB請(qǐng)求處理系列》提上日程了,一直答應(yīng)小伙伴們給分享一套完整的WEB請(qǐng)求處理流程:從瀏覽器、Ng...
    七寸知架構(gòu)閱讀 31,632評(píng)論 27 253
  • 本篇文章篇幅比較長(zhǎng),先來個(gè)思維導(dǎo)圖預(yù)覽一下。 一、概述 1.計(jì)算機(jī)網(wǎng)絡(luò)體系結(jié)構(gòu)分層 2.TCP/IP 通信傳輸流 ...
    滌生_Woo閱讀 55,153評(píng)論 24 557
  • 忙忙碌碌,仿佛被一股無形的力量推扯著,快到腳步越來越虛浮,頭腦越來越懵懂,如同一臺(tái)上弦音樂盒上那個(gè)不停旋轉(zhuǎn)的...
    新月5046閱讀 377評(píng)論 0 0