移動互聯網發展到如今,用戶的聯網方式已經完成了由流量依賴到Wifi依賴的轉變。雖然網絡環境在變好,但也對網絡的應用提出了更高的要求,同時開發人員對網絡的重視度卻在降低。確實Wifi場景下用戶的網絡質量變好了,並且用戶對網絡流量消耗的敏感度也在降低。可是對網絡問題的忽視,在網絡狀態很差的場景下,會表現的很明顯。html
過多以及沒有通過處理的網絡請求,會消耗用戶的網絡流量。Android用戶通常都會安裝手機管理類App,能夠方便清楚查看到每一個App耗費的流量,高流量消耗會致使常常處於非Wifi場景下的用戶卸載。java
與第一條流量消耗相似,耗電也會致使用戶最終的卸載。android
網絡請求耗時會給用戶帶來卡頓的產品體驗,雖然可使用Loading提高用戶體驗,但屬於治標不治本。例如最近我在使用某火爆單車App,每次網絡請求都能超出個人耐心,因而我就轉投另外一款單車App!git
Android Studio自帶的Network Monitor簡單直觀,能夠看出時間段以內的網絡請求數量及訪問速率;
github
使用Charles、Fiddler等抓包工具一樣能夠實現Network Monitor的功能,並且更增強大。
sql
Stetho是Facebook出品的一個Android應用的調試工具。無需Root便可經過Chrome,在Chrome Developer Tools中可視化查看應用佈局,網絡請求,sqlite,preference等。一樣集成了Stetho以後也能夠很方便的查看網絡請求的各類狀況。
json
網絡優化主要從三個方面進行:1. 速度;2. 成功率;3. 流量。緩存
HTTP協議上的Gzip編碼是一種用來改進WEB應用程序性能的技術,用來減小傳輸數據量大小,減小傳輸數據量大小有兩個明顯的好處:性能優化
DNS解析的失敗率佔聯網失敗中很大一種,並且首次域名解析通常須要幾百毫秒。針對此,咱們能夠不用域名,才用IP直連省去 DNS 解析過程,節省這部分時間。服務器
另外熟悉阿里雲的小夥伴確定知道HttpDns:HttpDNS基於Http協議的域名解析,替代了基於DNS協議向運營商Local DNS發起解析請求的傳統方式,能夠避免Local DNS形成的域名劫持和跨網訪問問題,解決域名解析異常帶來的困擾。
圖片(文件)的上傳失敗率比較高,不只僅由於大文件,同時帶寬、時延、穩定性等因素在此場景下的影響也更加明顯;
備註:圖片上傳是一項看似簡單、共性不少但實際上覆雜、須要細分的工做。移動互聯網的場景和有線的場景是有不少區別的,例如移動網絡的質量/帶寬常常會發生「跳變」,但有線網絡倒是「漸變」。
圖片上傳其它細節請參見《移動App性能評測與優化》一書。
使用最新的協議,Http協議有多個版本:0.九、1.0、1.一、2等。新版本的協議通過再次的優化,例如:
新的版本不只能夠節省資源,一樣能夠減小流量;我對Http2並無實際接入經驗,此處僅從原理進行分析。
合併網絡請求,減小請求次數。對於一些接口類如統計,無需實時上報,將統計信息保存在本地,而後根據策略統一上傳。這樣頭信息僅需上傳一次,減小了流量也節省了資源。
對服務端返回數據進行緩存,設定有效時間,有效時間以內不走網絡請求,減小流量消耗。對網絡的緩存能夠參見HttpResponseCache。
備註:咱們也能夠自定義緩存的實現,一些網絡庫例如:Volley、Okhttp等都有好的實踐供參考。
根據網絡狀態對網絡請求進行區別對待,2G與Wifi狀態下網絡質量確定是不同的,那對應的網絡策略也應該是不同的。例如:在Wifi場景下能夠進行數據的預取、一些統計的集中上傳等;而在2G場景下此類操做以及網絡請求的次數策略都應該調低。網絡狀態能夠由TelephonyManager.getNetworkType()方法獲取到。
備註:還可使用Facebook的開源庫network-connection-class來作網絡狀態的判斷。
斷點續傳,文件、圖片等的下載,採用斷點續傳,不浪費用戶以前消耗過的流量;
重試策略,一次網絡請求的失敗,須要屢次的重試來判定最終的失敗,能夠參考Volley的重試機制實現。
Protocol Buffer
Protocol Buffer是Google的一種數據交換的格式,它獨立於語言,獨立於平臺。相較於目前經常使用的Json,數據量更小,意味着傳輸速度也更快。
具體的對比能夠參見:《Protobuffer和json深度對比》。
儘可能避免客戶端的輪詢,而使用服務器推送的方式;
數據更新採用增量,而不是全量,僅將變化的數據返回,客戶端進行合併,減小流量消耗;
參考:
歡迎關注微信公衆號:按期分享Java、Android乾貨!