消息推送机制技术设计

消息推送机制技术设计

ID:19305866

大小:246.00 KB

页数:9页

时间:2018-09-30

消息推送机制技术设计_第1页
消息推送机制技术设计_第2页
消息推送机制技术设计_第3页
消息推送机制技术设计_第4页
消息推送机制技术设计_第5页
资源描述:

《消息推送机制技术设计》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、消息推送技术消息推送技术消息推送Web层消息推送套接字HTTP请求轮询简单轮询长轮询HTTP流HTML5WebSocket多客户端支持APIs多样网络连接不稳定最小化流量服务层消息服务JavaMessageService消息域消息确认技术设计目标Web层设计Pushlets组件JS客户端服务层设计处理步骤消息表逻辑架构推时序关键点参考消息推送消息推送是针对Web应用开发领域的技术,指服务端以主动方式将信息送达客户端。主要用于提升用户体验,避免用户刷新页面从服务端拉取数据。例如Web邮件中自动出现刚收到的邮件项,Web即时通讯自动提示新到消息

2、等应用场景。要实现消息推送机制,涉及两方面的内容:●Web层消息推送●服务层消息服务Web层消息推送套接字可以使用套接字接口进行全双工通讯。可以通过FlashXMLSocket、JavaApplet技术实现。但由于实现方案与厂商技术绑定过紧,不属于Web标准化范畴,并且存在一些限制(通讯端口开启安全、客户端插件),这里不进行描述。HTTP请求轮询目前的Web应用是基于HTTP协议的,其规定了请求-响应的处理模型,位于应用层的单工通讯模式使得纯粹意义上的服务端推送方式变得难以实现。为了基于HTTP协议进行“推送”实现,可由客户端发起HTTP请

3、求轮询,服务端在请求后返回响应。根据轮询时间、请求处理方式,分为以下三种推。简单轮询客户端一般以定时方式发起请求,服务端处理后返回响应。●原理、客户端/服务端实现简单●可根据应用场景调整轮询时间间隔●服务端需要处理大量请求长轮询客户端发起请求后服务端将该请求挂起(不返回响应),直到超时、异常或需要处理响应(推内容)才返回。客户端收到响应后再次请求(即轮询)服务端,并处理响应。●实时性高●服务端需要管理挂起请求HTTP流客户端发起请求后服务器端处理请求,并通过HTTP流一直向客户端写入数据,直到超时或异常才返回响应。连接断开后客户端再次请求服

4、务端,属于长轮询的一种。HTML5WebSocket这是标准化的客户端全双工通讯规范,但由于目前服务端规范尚未成型,且考虑到现有客户端对HTML5的支持有限,这里不进行描述。多客户端支持上述介绍是针对浏览器客户端的,在实际应用场景中,还需要考虑其他客户端支持,例如iOS、Android等。在移动客户端方面,需要考虑如下几点。APIs多样不同客户端本地APIs接口存在差异,但都支持基本的HTTP协议。直接基于HTTP协议进行开发可将差异最小化。网络连接不稳定通讯信道打开后不一定能长时间维护,客户端与服务端的状态管理复杂。最小化流量需要尽量最小

5、化网络流量,提升移动客户端可用性。服务层消息服务消息是系统或组件间通讯的一种低耦合方式,是系统级异步架构的基础。在Web消息推送中,服务端管理应用状态,当状态发生变迁时需要通知客户端,完成消息推送。JavaMessageService需要重点关注如下技术点:消息域●点对点只有一个客户端可以接收到消息。●发布/订阅广播给订阅的客户端。可配置持久化订阅。消息确认●会话本地事务提交时会对收到的消息进行确认,回滚时将重传所有消息●非本地事务确认:Session.AUTO_ACKNOWLEDGE、Session.CLIENT_ACKNOWLEDGE、

6、Session.DUPS_OK_ACKNOWLEDGE技术设计目标●支持浏览器客户端的推送●高性能、高可靠●模块化,不与应用耦合●未来可支持多种移动客户端Web层设计Web层考虑采用开源组件Pushlets进行实现。Pushlets组件Pushlets基于HTTP协议的发布/订阅模型,提供了Poll(轮询)、Pull(拉)两种推方式实现。其中Pull即长轮询方式,当有消息时就返回。●发布:GET/POST或方法调用(Dispatcher接口)●订阅:GET流,拉/轮询模式●树形主题:可层次化订阅●协议格式:JS,XML(JSON尚未支持)●

7、对使用HTTP协议的客户端都可用●易扩展:例如事件源实现●方便整合:可独立为Web应用,也可为Web应用组件●多种实现:J2EE/servlets,JavaScript(AJAX)JS客户端●js-pushlet-client.js○使用“隐藏iframe技巧”○格式:JavaScript函数事件●ajax-pushlet-client.js○使用XMLHttpRequest○格式:XML○不支持HTTP流使用AJAX客户端,较为灵活,便于封装。服务层设计服务层消息服务采用应用服务器JMS中间件。通过发布/订阅模型实现状态同步。处理步骤1.

8、配置主题订阅2.应用状态变迁时发布JMS消息3.JMS消息监听器将监听到的消息发布到Pushlets4.将该消息写入Web层消息表消息表保存推送多的消息记录,用于客户端刷新时/多

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。