一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

Android Push開源方案解析

 quasiceo 2014-04-09

Android Push開源方案解析

2012-12-21 14:05 佚名 我要評論(0) 字號:T | T
一鍵收藏,隨時查看,分享好友!

在 Android 上,因?yàn)?Google 自己實(shí)現(xiàn)的 Android 標(biāo)配的 GCM (Google Cloud Messaging,原來叫 C2DM) 在國內(nèi)基本不可用,所以,對于開發(fā)者來說,如果需要 Push功能,怎么樣選擇成為了一個問題。

在 Android 上,因?yàn)?Google 自己實(shí)現(xiàn)的 Android 標(biāo)配的 GCM (Google Cloud Messaging,原來叫 C2DM) 在國內(nèi)基本不可用,所以,對于開發(fā)者來說,如果需要 Push功能,怎么樣選擇成為了一個問題。
到目前為止,國內(nèi)尚沒有完全向開發(fā)者免費(fèi)、開放的 Push 服務(wù)可用。國外有幾家第三方推送服務(wù),但一般都要收費(fèi)。所以一般來說,國內(nèi)的開發(fā)者不得不考慮自己來搭建 Push服務(wù)。
自己構(gòu)建 Push服務(wù)時,一個比較自然的選擇就是,基于開源的現(xiàn)在方案來做。

使用 Google或者百度搜索 “Android Push 推送”等關(guān)鍵詞,表明已經(jīng)有不少人研究過。排在前邊的是這樣幾篇文章:
  • Android實(shí)現(xiàn)推送方式解決方案
  • 用androidpn來實(shí)現(xiàn)推送
  • Android上實(shí)現(xiàn)Push
  • Android Push Notification實(shí)現(xiàn)信息推送使用
     

上面文章提及的方案里,基本上都提及了一個開源的 Android Push實(shí)現(xiàn): androidpn。
androidpn 它本質(zhì)上服務(wù)器端基于 Openfire,客戶端基于 asmack,這二者都最 XMPP  IM 開源實(shí)現(xiàn)里的二個基本組件,應(yīng)該說 androidpn 只是把二者更多地結(jié)合起來用于做 Push的場景。
筆者做過聊天App,愿意在這里,把基于 XMPP開源系統(tǒng)做 IM 的實(shí)踐經(jīng)驗(yàn)分享給大家。
我們做聊天類App,比較自然地,剛開始時也是從研究開源的 XMPP IM 系統(tǒng)入手。

先說服務(wù)器端選擇。Openfire 是一個 XMPP  最古老的開源 IM Server,幾乎所有做 IM 的都應(yīng)該有研究過。但是,它也是最不合適運(yùn)用到生產(chǎn)的 IM Server,因?yàn)椋簡螜C(jī)并發(fā)很有限,集群方案不成熟,代碼古老而缺乏及時更新。舉個具體的例子:Openfire 的集群組件叫 Connection Manager,但是,你在 Openfire官方網(wǎng)站可以看到,最近一個版本是 2009 年 2 月份發(fā)布的??梢?,基于Openfire 實(shí)現(xiàn)的 androidpn 的根基是不夠穩(wěn)的。

更新:與一個基于 Openfire 做聊天App的朋友交流,他們的用戶量比較大,有多個 Openfire 節(jié)點(diǎn)做集群。他們對 Openfire 做了很多改造,比如 XMPP 協(xié)議交互復(fù)雜,要簡化;XMPP 協(xié)議文本臃腫,則轉(zhuǎn)換為二進(jìn)制。集群方面,則完全是自己重新開發(fā)的。他們最多單點(diǎn)負(fù)載 30 萬用戶。
還有另外二個其實(shí)相對好一點(diǎn)的選擇: ejabberd, tigase。ejabberd 是用 Erlang語言實(shí)現(xiàn)的,懂 Erlang 的用戶很少,所以一般不會選。我們當(dāng)時初步的聊天服務(wù)器端選擇是 tigase (Java實(shí)現(xiàn)的)。
tigase 作者維護(hù)很活躍,集群測試結(jié)果能夠支撐比較大的容量,這是吸引我們的地方。但經(jīng)過實(shí)際生產(chǎn)運(yùn)營情況來看,由于其集群方案實(shí)現(xiàn)的復(fù)雜性,以及單節(jié)點(diǎn)容量的有限,我們對支撐到 50 萬用戶在集群節(jié)點(diǎn)上沒有信心,所以在到達(dá) 50 萬用戶之前,趕快自己開發(fā)了替代方案。
再來說 XMPP 協(xié)議與客戶端的問題:對于移動客戶端來說,原始的 XMPP 有些復(fù)雜而且流量消耗大。XMPP 本質(zhì)上協(xié)議體都在字符串的 xml 結(jié)構(gòu)上,每個協(xié)議都量一堆的字符串,xml里還有很多無意義的結(jié)構(gòu)。另外,XMPP為了其靈活性,就登錄這個事情都需要有 N 個來回。對于手機(jī)客戶端很在乎流量與電量來說,XMPP 比較笨重。
我們的作法是:協(xié)議格式上改為二進(jìn)制,協(xié)議內(nèi)容上簡化交互,但保留對原始  XMPP的兼容。
androidpn 是開源的 Push 實(shí)現(xiàn),是基于 XMPP 開源組件集成的,它沒有為手機(jī)應(yīng)用場景做必要的優(yōu)化。另外,XMPP  本質(zhì)上雙向 IM 協(xié)議,而直接基于 XMPP 來實(shí)現(xiàn) Push 功能,也是沒有特別地為  Push 的特點(diǎn)優(yōu)化的,比如客戶端網(wǎng)絡(luò)連接的策略等。

總結(jié)一下以 androidpn 為典型的開源 Android Push 方案會存在的問題:
1)容量大了開源服務(wù)器實(shí)現(xiàn)頂不住,還是需要自己去改進(jìn)開源實(shí)現(xiàn),或者完全重新用新方案,開發(fā)投入與高成本是不可避免的。
2)協(xié)議與實(shí)現(xiàn)上如流量消耗、網(wǎng)絡(luò)連接策略等,不是專門為移動 Push 優(yōu)化過的,是不經(jīng)濟(jì)的。

基于我們團(tuán)隊(duì)基于 XMPP開源系統(tǒng)實(shí)現(xiàn)聊天App的實(shí)踐經(jīng)驗(yàn),我們得出的結(jié)論是,在移動端的 IM場景里,開源方案不是個可用好用的方案。后來我們自己完全重新架構(gòu)了整套系統(tǒng)。之后,正是基于這套全新架構(gòu)的 IM 系統(tǒng),演變出來了極光推送。
極光推送專門為移動場景下的實(shí)時 Push 來研發(fā),我們想要去解決國內(nèi) Android 開發(fā)者沒有可用、好用的 Push方案的問題,是免費(fèi)的,完全向普通開發(fā)者開放。如果你也有這個 Android Push 的需求,不妨到極光推送官方網(wǎng)站進(jìn)一步地了解。

【編輯推薦】

【責(zé)任編輯:冰凝兒 TEL:(010)68476606】


    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    亚洲最新的黄色录像在线| 成人欧美精品一区二区三区| 亚洲五月婷婷中文字幕| 久久国产精品熟女一区二区三区| 欧美区一区二在线播放| 中文字幕日韩精品人一妻| 国产精品十八禁亚洲黄污免费观看 | 久草视频在线视频在线观看| 国产日韩精品激情在线观看| 91精品国产综合久久精品| 精品一区二区三区免费看| 中文字幕人妻日本一区二区| 在线免费视频你懂的观看| 中文字幕欧美精品人妻一区| av免费视屏在线观看| 国产精品美女午夜视频| 少妇一区二区三区精品| 国产精品久久男人的天堂| 欧美亚洲另类久久久精品| 精品国产亚洲一区二区三区| 九九热这里只有免费精品| 国产偷拍精品在线视频| 日韩一区二区三区观看| 亚洲欧洲一区二区综合精品| 国产成人午夜福利片片| 东京热男人的天堂一二三区| 日韩精品你懂的在线观看| 国产欧美亚洲精品自拍| 国产又黄又爽又粗视频在线| 国产91麻豆精品成人区| 欧美一区二区三区99| 国产专区亚洲专区久久| 91精品国产av一区二区| 99久久免费中文字幕| 国产又黄又猛又粗又爽的片 | 欧美国产日本免费不卡| 亚洲精品一区二区三区免| 人妻精品一区二区三区视频免精| 中文字幕人妻一区二区免费| 久久大香蕉一区二区三区| 亚洲国产另类久久精品|