【文章分享】移動無線網路長串連

來源:互聯網
上載者:User

標籤:android   style   blog   http   color   io   ar   strong   sp   

============問題描述============


移動互連網應用現狀

因為手機平台本身、電量、網路流量的限制,移動互連網應用在設計上跟傳統 PC 上的應用很大不一樣,需要根據手機本身的特點,盡量的節省電量和流量,同時又要儘可能的保證資料能及時到達用戶端。

為瞭解決資料同步的問題,在手機平台上,常用的方法有2種。一種是定時去伺服器上查詢資料,也叫Polling,還有一種手機跟伺服器之間維護一個 TCP 長串連,當伺服器有資料時,即時推送到用戶端,也就是我們說的 Push。

從耗費的電量、流量和資料送達的及時性來說,Push 都會有明顯的優勢,但 Push 的實現和維護成本相對較高。在移動無線網路下維護長串連,相對也有一些技術上的難度。本文試圖給大家介紹一下我們極光推送在 Android 平台上是如何維護長串連。

移動無線網路的特點

因為 IP v4 的 IP 量有限,電訊廠商分配給手機終端的 IP 是電訊廠商內網的 IP,手機要串連 Internet,就需要通過電訊廠商的網關做一個網路位址轉譯(Network Address Translation,NAT)。簡單的說電訊廠商的網關需要維護一個外網 IP、連接埠到內網 IP、連接埠的對應關係,以確保內網的手機可以跟 Internet 的伺服器通訊。



NAT 功能由圖中的 GGSN 模組實現。

大部分移動無線網路電訊廠商都在鏈路一段時間沒有資料通訊時,會淘汰 NAT 表中的對應項,造成鏈路中斷。


Android 平台上長串連的實現


為了不讓 NAT 表失效,我們需要定時的發心跳,以重新整理 NAT 表項,避免被淘汰。

Android 上定時運行任務常用的方法有2種,一種方法用 Timer,另一種是AlarmManager。

Timer

Android 的 Timer 類可以用來計劃需要迴圈執行的任務,Timer 的問題是它需要用 WakeLock 讓 CPU 保持喚醒狀態,這樣會大量消耗手機電量,大大減短手機待機時間。這種方式不能滿足我們的需求。

AlarmManager


AlarmManager 是 Android 系統封裝的用於管理 RTC 的模組,RTC (Real Time Clock) 是一個獨立的硬體時鐘,可以在 CPU 休眠時正常運行,在預設的時間到達時,通過中斷喚醒 CPU。

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


伺服器設計


當有大量的手機終端需要與伺服器維持長串連時,對伺服器的設計會是一個很大的挑戰。

假設一台伺服器維護10萬個長串連,當有1000萬使用者量時,需要有多達100台的伺服器來維護這些使用者的長串連,這裡還不算用於做備份的伺服器,這將會是一個巨大的成本問題。那就需要我們儘可能提高單台伺服器接入使用者的量,也就是業界已經討論很久了的 C10K 問題。

C2000K

針對這個問題,我們專門成立了一個項目,命名為C2000K,顧名思義,我們的目標是單機維持200萬個長串連。最終我們採用了多訊息迴圈、非同步非阻塞的模型,在一台雙核、24G記憶體的伺服器上,實現峰值維持超過300萬個長串連。


後記


穩定維護長串連是推送平台的一個基礎,極光推送團隊將會在這方面長期投入,以保證使用者能有效節省電量、流量,同時資料能即時送達。

============解決方案1============


軟文軟文軟文

============解決方案2============


學習了,感謝樓主分享

============解決方案3============


長知識了,長串連實現起來不容易啊

============解決方案4============


非常強大,支援下~

============解決方案5============


學習下長串連的知識,多謝樓主分享

============解決方案6============


單機並發300W麼,相當的犀利啊

============解決方案7============


支援下沒錢看哦







============解決方案8============


good,還是挺靠譜的啊

============解決方案9============


厲害  漲見識了

============解決方案10============


雷射推送部落格上的文章。。。

============解決方案11============


可以簡訊push啊,終端只需要註冊receiver就行了.

============解決方案12============


貌似和GCM差不多吧

============解決方案13============


謝謝樓主;感謝

============解決方案14============


不錯不錯不錯

============解決方案15============


在及時響應的同時還省電省流量對吧

============解決方案16============


貌似很強大,學習學習了

============解決方案17============


漲知識了,長串連才是最佳方案啊

============解決方案18============


有沒有試過用IPV6來做?

【文章分享】移動無線網路長串連

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.