热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Androi的消息推送机制

Android消息推送机制研究1.基于HTTP协议的推送机制基于HTTP协议的推送机制是一种请求-响应模式,由于HTTP协议是应用层的单工通信模式,因此它很难实现真正意义上的即时推

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

《Androi的消息推送机制》 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协议的推送机制为例,如下图所示,客户端首先和服务器端进行连接,连接后消息可以在服务器端和客户端、客户端和客户端间双向传输。

《Androi的消息推送机制》 Paste_Image.png

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


推荐阅读
  • 时序数据是指按时间顺序排列的数据集。通过时间轴上的数据点连接,可以构建多维度报表,揭示数据的趋势、规律及异常情况。 ... [详细]
  • 微信小程序支付官方参数小程序中代码后端发起支付代码支付回调官方参数文档地址:https:developers.weixin.qq.comminiprogramdeva ... [详细]
  • Activity跳转动画 无缝衔接
    Activity跳转动画 无缝衔接 ... [详细]
  • MQTT介绍(MessageQueuingTelemetryTransport,消息队列遥测传输)是IBM推出的一种针对移动终端设备的基于TCPIP的发布订阅协议可以连接大量的远程 ... [详细]
  • Spring Boot 初学者指南(第一部分)
    本文介绍了Spring Boot框架的基础知识,包括其设计理念、主要优势以及如何简化传统的J2EE开发流程。 ... [详细]
  • 本文档提供了详细的MySQL安装步骤,包括解压安装文件、选择安装类型、配置MySQL服务以及设置管理员密码等关键环节,帮助用户顺利完成MySQL的安装。 ... [详细]
  • 本文介绍了多种Eclipse插件,包括XML Schema Infoset Model (XSD)、Graphical Editing Framework (GEF)、Eclipse Modeling Framework (EMF)等,涵盖了从Web开发到图形界面编辑的多个方面。 ... [详细]
  • 深入浅出:Hadoop架构详解
    Hadoop作为大数据处理的核心技术,包含了一系列组件如HDFS(分布式文件系统)、YARN(资源管理框架)和MapReduce(并行计算模型)。本文将通过实例解析Hadoop的工作原理及其优势。 ... [详细]
  • 本文详细介绍了JavaScript中数组的转换方法、栈方法、队列方法、重排序方法及操作方法,包括toLocaleString()、toString()、valueOf()等基本转换方法,以及push()、pop()、shift()、unshift()等用于模拟栈和队列行为的方法。 ... [详细]
  • LeetCode 102 - 二叉树层次遍历详解
    本文详细解析了LeetCode第102题——二叉树的层次遍历问题,提供了C++语言的实现代码,并对算法的核心思想和具体步骤进行了深入讲解。 ... [详细]
  • Awk是一款功能强大的文本分析与处理工具,尤其在数据解析和报告生成方面表现突出。它通过读取由换行符分隔的记录,并按照指定的字段分隔符来划分和处理这些记录,从而实现复杂的数据操作。 ... [详细]
  • 流处理中的计数挑战与解决方案
    本文探讨了在流处理中进行计数的各种技术和挑战,并基于作者在2016年圣何塞举行的Hadoop World大会上的演讲进行了深入分析。文章不仅介绍了传统批处理和Lambda架构的局限性,还详细探讨了流处理架构的优势及其在现代大数据应用中的重要作用。 ... [详细]
  • 【实践】基于RTThread的智慧路灯案例实验分享
    之前分享了基于LiteOS的智慧农业案例实验分享基于LiteOS的智慧农业案例实验分享,阅读量挺不错,看样子大家都挺喜欢这种实验。那咱们就再来一个类似的实验:基于RT-Thread ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • Mosquitto常用命令
    1mosquitto服务器的搭建服务器这里使用了阿里云的服务器,mosquitto默认需要1883的TCP入端口。需要在安全策略里设置一下。端口当然也可以选其他端口进 ... [详细]
author-avatar
我爱技术交流
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有