Androi的消息推送机制

Android消息推送机制研究
1.基于HTTP协议的推送机制
基于HTTP协议的推送机制是一种请求-响应模式,由于HTTP协议是应用层的单工通信模式,因此它很难实现真正意义上的即时推送。用HTTP协议实现推送有以下两种方式.
(1)定期轮询:
这种方式是使客户端每隔固定时间向服务器端以post方式发出HTTP请求。在一次请求的开始,客户端询问服务器是否存在需要推送的消息,服务器端收到请求并处理,随后向客户端响应处理结果,这样一次请求就结束了。一段固定时间后,客户端将再次向服务器端发出询问请求并等待服务器端的返回结果。
(2)长轮询:
这种方式是服务器端在接收到客户端向其发出的请求时将请求挂起,直到该连接请求出现异常、超时、或者需要推送消息时再处理该请求,并向客户端返回响应,客户端接收到响应后会立即再向服务器端请求连接。这样就使得服务器与客户端之间的连接始终未中断,比客户端定期轮询的方式具有更好的实时性。
基于HTTP协议的推送机制实际上并不是真正的推送,而是依赖客户端请求-服务器端响应的模式。虽然该机制的实现简单快速且可控性强,但推送具有延迟性,实时性差。另外,虽然其中长轮询形式的推送具有一定的实时性,但是服务器端需要管理大量挂起的请求,会造成服务器端资源消耗,同时由于HTTP协议是无状态的,服务器端不能监控客户端的在线离线状态,因此就不能判断推送的消息能否达到客户端。
2.基于C2DM的推送机制
C2DM (Cloud to Device Messaging)服务是Google公司提供的移动终端消息推送服务。开发者可以将该服务引入自己开发的应用程序中,服务器端推送给客户端的消息是经过C2DM服务器推送的,客户端也可以直接与服务器通信获取信息。其中C2DM服务器类似与推送消息的中间转发者,负责处理用户权限、消息队列等事务并向指定客户端转发由服务器推送的消息。具体使用机制如下图所示。

Paste_Image.png

(1)客户端首先将应用名和账号发送给C2DM服务器进行注册,注册成功后客户端会收到并存储C2DM返回的注册标识。
(2)客户端向自己的服务器发送该标识和注册成功的账号,使得服务器能使用标识和账号向C2DM请求消息推送。
(3)当服务器需要向客户端发送数据时,获取该客户端注册使用C2DM功能的用户账号的登陆权限。
(4)服务器把要发送的消息、客户端注册标识、账号登陆权限一并发送给C2DM服务器。
(5) C2DM服务器会把收到的消息推送给相应的客户端。
由于其为Google公司提供的原生服务,因此无需实现和部署服务端。然而,正因为其原生性,使其需要用户绑定Google帐号,同时由于该推送机制依赖于Google官方提供的C2DM服务器(服务器在国外),使得该服务在国内不够稳定,常常无法提供服务。另外,国内部分手机厂商,例如中兴、华为等可能会去掉Google的这种原生服务,样推送功能将不能使用。
3.基于MQTT协议的推送机制
MQTT (Message Queuing Telemetry Transport)是由 IBM 在 2001 年发布的轻量级的消息传输协议,支持可发布/可订阅的消息推送模式。协议的轻量级使它十分适合在用在资源受限的环境该协议最初是为物联网设计的,现在也可用来实现消息推送。推送机制的实现主要依靠一个实现了MQTT协议的代理服务器,客户端首先连接代理服务器,然后进行消息订阅,同时,客户端也可向服务器发布消息,其他客户端订阅后也可接收这些消息,因此消息也可在客户端之间传输。该推送机制中代理服务器一般是采用IBM的MQTT服务器RSMB(Really Small Message Broker),客户端一般是采用 IBM 的提供的 wmqtt.jar 包。
MQTT协议是基于代理的“发布/订阅”模式的消息传输协议。由于该协议简洁、小巧、可扩展性强的优点,使得基于该协议的推送机制较省流量和省电,目前已有C++语言编写的服务端组件RSMB。然而由于基于MQTT协议的推送机制实现较复杂,目前这种机制还不够成熟。另外,由于服务器端组件RSMB不开源,也使得在之上的二次开发很困难。
4.基于第三方的推送机制
第三方推送平台有百度云推送、极光推送、_蝶推送、个推等。这些平台是面向个人幵发者或者企业幵发者的,它们一般是按需收费的,能提供多样化的推送。以百度云推送为例,它支持推送文字和富媒体,支持向单用户和群组用广的推送等。开发者开发过程中需要在将第三方平台的SDK集成到客户端,这样,服务器端推送消息吋调用第三方服务器的接口,就可以实现推送消息至客户端。
第三方推送最大的优点是支持多种格式数据的推送和超高并发连接数,然而他们也存在缺陷,例如极光推送使用的自定义的二进制协议,不支持推送信息的加密和身份认证,百度云的加密推送需要额外付费等。另外,采用第三方企业的SDK有程序嵌入的顾虑,存在风险。
5.基于XMPP协议的推送机制
基于XMPP协议的消息推送机制继承了 XMPP协议的优点,具备很强的灵活性和可扩展性,并且将复杂性从客户端转移到服务器端。H前基于该协议己有比较成熟的推送框架,最著名的服务器端推送框架是Openfire,其采用Java开发,安装、配置和使用都十分容易,并利用Web平台进行管理,基于Openfire能够轻松进行二次开发并实现个性化的推送功能。而客户端框架是Spark包,它完整的实现了 XMPP协议的幵源API库,同时,为适应Android运行环境,该包还存在android平台上的构建版本Spark。另外,H前基于XMPP协议还存在另一个推送机制 Androidpn。它是一个整合方案,其客户端基于Spark,服务器端的实现是基于Openfire,并精简了 Openfire过于繁复庞大的功能,仅仅分离出了消息推送服务。
以Openfire和Spark包构建的基于XMPP协议的推送机制为例,如下图所示,客户端首先和服务器端进行连接,连接后消息可以在服务器端和客户端、客户端和客户端间双向传输。
Paste_Image.png

基于XMPP协议的推送机制能够实现真正意义上的即时推送,不用像C2DM服务需要担心由于服务器在国外带来的推送服务的不稳定性,也不存在使用第三方的SDK带来的安全风险。同时该机制继承了 XML的优点,具备很强的可扩展性,可以实现复杂的通信。虽然目前基于XMPP协议的推送只支持文字格式的推送,但己满足大部分系统的推送需求,因为一般情况下,推送消息只是告诉客户端服务器端有变化,而变化的具体内容则由客户端主动到服务器获取。目前已有Java语言编写的服务器端与客户端开源程序,使开发者很容易进行二次开发,根据具体需求搭建自己的系统。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,311评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,339评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,671评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,252评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,253评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,031评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,340评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,973评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,466评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,937评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,039评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,701评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,254评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,259评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,497评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,786评论 2 345

推荐阅读更多精彩内容