自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

極光推送技術(shù)原理:移動無線網(wǎng)絡(luò)長連接

移動開發(fā)
因?yàn)槭謾C(jī)平臺本身、電量、網(wǎng)絡(luò)流量的限制,移動互聯(lián)網(wǎng)應(yīng)用在設(shè)計上跟傳統(tǒng) PC 上的應(yīng)用很大不一樣,需要根據(jù)手機(jī)本身的特點(diǎn),盡量的節(jié)省電量和流量,同時又要盡可能的保證數(shù)據(jù)能及時到達(dá)客戶端。

移動互聯(lián)網(wǎng)應(yīng)用現(xiàn)狀

因?yàn)槭謾C(jī)平臺本身、電量、網(wǎng)絡(luò)流量的限制,移動互聯(lián)網(wǎng)應(yīng)用在設(shè)計上跟傳統(tǒng) PC 上的應(yīng)用很大不一樣,需要根據(jù)手機(jī)本身的特點(diǎn),盡量的節(jié)省電量和流量,同時又要盡可能的保證數(shù)據(jù)能及時到達(dá)客戶端。

為了解決數(shù)據(jù)同步的問題,在手機(jī)平臺上,常用的方法有2種。一種是定時去服務(wù)器上查詢數(shù)據(jù),也叫Polling,還有一種手機(jī)跟服務(wù)器之間維護(hù)一個 TCP 長連接,當(dāng)服務(wù)器有數(shù)據(jù)時,實(shí)時推送到客戶端,也就是我們說的 Push。

從耗費(fèi)的電量、流量和數(shù)據(jù)送達(dá)的及時性來說,Push 都會有明顯的優(yōu)勢,但 Push 的實(shí)現(xiàn)和維護(hù)成本相對較高。在移動無線網(wǎng)絡(luò)下維護(hù)長連接,相對也有一些技術(shù)上的難度。本文試圖給大家介紹一下極光推送在 Android 平臺上如何維護(hù)長連接。

移動無線網(wǎng)絡(luò)的特點(diǎn)

因?yàn)?IP v4 的 IP 量有限,運(yùn)營商分配給手機(jī)終端的 IP 是運(yùn)營商內(nèi)網(wǎng)的 IP,手機(jī)要連接 Internet,就需要通過運(yùn)營商的網(wǎng)關(guān)做一個網(wǎng)絡(luò)地址轉(zhuǎn)換(Network Address Translation,NAT)。簡單的說運(yùn)營商的網(wǎng)關(guān)需要維護(hù)一個外網(wǎng) IP、端口到內(nèi)網(wǎng) IP、端口的對應(yīng)關(guān)系,以確保內(nèi)網(wǎng)的手機(jī)可以跟 Internet 的服務(wù)器通訊。

圖片源自 cisco.com. 

NAT 功能由圖中的 GGSN 模塊實(shí)現(xiàn)。

大部分移動無線網(wǎng)絡(luò)運(yùn)營商都在鏈路一段時間沒有數(shù)據(jù)通訊時,會淘汰 NAT 表中的對應(yīng)項,造成鏈路中斷。

Android 平臺上長連接的實(shí)現(xiàn)

為了不讓 NAT 表失效,我們需要定時的發(fā)心跳,以刷新 NAT 表項,避免被淘汰。

Android 上定時運(yùn)行任務(wù)常用的方法有2種,一種方法用 Timer,另一種是AlarmManager。

Timer

Android 的 Timer 類可以用來計劃需要循環(huán)執(zhí)行的任務(wù),Timer 的問題是它需要用 WakeLock 讓 CPU 保持喚醒狀態(tài),這樣會大量消耗手機(jī)電量,大大減短手機(jī)待機(jī)時間。這種方式不能滿足我們的需求。

AlarmManager

AlarmManager 是 Android 系統(tǒng)封裝的用于管理 RTC 的模塊,RTC (Real Time Clock) 是一個獨(dú)立的硬件時鐘,可以在 CPU 休眠時正常運(yùn)行,在預(yù)設(shè)的時間到達(dá)時,通過中斷喚醒 CPU。

這意味著,如果我們用 AlarmManager 來定時執(zhí)行任務(wù),CPU 可以正常的休眠,只有在需要運(yùn)行任務(wù)時醒來一段很短的時間。極光推送的 Android SDK 就是基于這種技術(shù)實(shí)現(xiàn)的。

服務(wù)器設(shè)計

當(dāng)有大量的手機(jī)終端需要與服務(wù)器維持長連接時,對服務(wù)器的設(shè)計會是一個很大的挑戰(zhàn)。

假設(shè)一臺服務(wù)器維護(hù)10萬個長連接,當(dāng)有1000萬用戶量時,需要有多達(dá)100臺的服務(wù)器來維護(hù)這些用戶的長連接,這里還不算用于做備份的服務(wù)器,這將會是一個巨大的成本問題。那就需要我們盡可能提高單臺服務(wù)器接入用戶的量,也就是業(yè)界已經(jīng)討論很久了的 C10K 問題。

C2000K

針對這個問題,我們專門成立了一個項目,命名為C2000K,顧名思義,我們的目標(biāo)是單機(jī)維持200萬個長連接。最終我們采用了多消息循環(huán)、異步非阻塞的模型,在一臺雙核、24G內(nèi)存的服務(wù)器上,實(shí)現(xiàn)峰值維持超過300萬個長連接。

后記

穩(wěn)定維護(hù)長連接是推送平臺的一個基礎(chǔ),極光推送團(tuán)隊將會在這方面長期投入,以保證用戶能有效的節(jié)省電量、流量,同時數(shù)據(jù)能實(shí)時送達(dá)。

責(zé)任編輯:閆佳明 來源: 51CTO
相關(guān)推薦

2010-09-07 13:51:26

無線網(wǎng)絡(luò)優(yōu)化

2010-09-28 10:21:11

無線網(wǎng)絡(luò)連接

2010-09-08 12:48:02

無線網(wǎng)絡(luò)配置

2010-09-16 09:59:36

無線網(wǎng)絡(luò)故障

2010-10-15 09:24:32

無線網(wǎng)絡(luò)原理

2010-12-21 10:36:46

無線網(wǎng)絡(luò)連接

2010-09-15 10:16:09

無線網(wǎng)絡(luò)連接

2010-09-08 14:27:18

無線網(wǎng)絡(luò)傳輸技術(shù)

2010-09-14 08:54:08

中文SSID無線網(wǎng)絡(luò)設(shè)

2010-09-08 09:04:45

無線網(wǎng)絡(luò)信號

2010-09-13 11:02:13

WLAN無線網(wǎng)絡(luò)覆蓋

2009-03-03 09:54:00

WiMedia無線

2014-07-30 09:13:07

2010-08-27 12:56:35

CDMA技術(shù)

2010-03-11 12:14:19

CDMA無線網(wǎng)絡(luò)

2009-03-09 09:51:00

2010-09-25 13:39:46

無線網(wǎng)絡(luò)連接

2010-09-27 13:47:19

無線網(wǎng)絡(luò)無線網(wǎng)卡設(shè)備

2010-09-06 13:11:55

無線網(wǎng)絡(luò)Ubuntu

2010-10-12 10:28:40

連接本地?zé)o線網(wǎng)絡(luò)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號