原文地址:http://88250.b3log.org/web-message-pushhtml
消息推送是针对 Web 应用开发领域的技术,指服务端以主动方式将信息送达客户端。主要用于提高用户体验,避免用户刷新页面从服务端拉取数据。例如 Web 邮件中自动出现刚收到的邮件项,Web 即时通信自动提示新到消息等应用场景。
要实现消息推送机制,涉及两方面的内容:前端
可使用套接字接口进行全双工通信。能够经过 Flash XMLSocket、Java Applet 技术实现。
但因为实现方案与厂商技术绑定过紧,不属于 Web 标准化范畴,而且存在一些限制(通信端口开启安全、客户端插件),这里不进行描述。html5
目前的 Web 应用是基于 HTTP 协议的,其规定了请求-响应的处理模型,位于应用层的单工通信模式使得纯粹意义上的服务端推送方式变得难以实现。
为了基于 HTTP 协议进行“推送”实现,可由客户端发起 HTTP 请求轮询,服务端在请求后返回响应。
根据轮询时间、请求处理方式,分为如下三种推。java
客户端通常以定时方式发起请求,服务端处理后返回响应。web
客户端发起请求后服务端将该请求挂起(不返回响应),直到超时、异常或须要处理响应(推内容)才返回。客户端收到响应后再次请求(即轮询)服务端,并处理响应。ajax
客户端发起请求后服务器端处理请求,并经过 HTTP 流一直向客户端写入数据,直到超时或异常才返回响应。链接断开后客户端再次请求服务端,属于长轮询的一种。浏览器
这是标准化的客户端全双工通信规范,但因为目前服务端规范还没有成型,且考虑到现有客户端对 HTML 5 的支持有限,这里不进行描述。安全
上述介绍是针对浏览器客户端的,在实际应用场景中,还须要考虑其余客户端支持,例如 iOS、Android 等。
在移动客户端方面,须要考虑以下几点。服务器
不一样客户端本地 APIs 接口存在差别,但都支持基本的 HTTP 协议。直接基于 HTTP 协议进行开发可将差别最小化。websocket
通信信道打开后不必定能长时间维护,客户端与服务端的状态管理复杂。
须要尽可能最小化网络流量,提高移动客户端可用性。
消息是系统或组件间通信的一种低耦合方式,是系统级异步架构的基础。
在 Web 消息推送中,服务端管理应用状态,当状态发生变迁时须要通知客户端,完成消息推送。
须要重点关注以下技术点:
Web 层考虑采用开源组件 Pushlets 进行实现。
Pushlets 基于 HTTP 协议的发布/订阅模型,提供了 Poll(轮询)、Pull(拉)两种推方式实现。其中 Pull 即长轮询方式,当有消息时就返回。
使用 AJAX 客户端,较为灵活,便于封装。
服务层消息服务采用应用服务器 JMS 中间件。经过发布/订阅模型实现状态同步。
保存推送多的消息记录,用于客户端刷新时/多客户端查找消息。
userId |
createdTime |
lastGetTime |
clients |
msg |
type |
timeout |
targetSys |
srcSys |
…. |
|
xxx |
xxx |
xxx |
[“pc”, “iOS”] |
{} |
公告 |
3天 |
OA |
OA |
消息体使用 JSON 字符串存放于 msg 字段中。其他字段可根据通用性进行抽取,好比用户名等。
消息监听器接收到消息时推 Pushlets,并进行记录写入(记录 lastGetTime 为写入时间,表示这条消息已经推送过)。
设置定时任务对超时记录进行删除。
JMS 消息系统为单独的通信总线服务独立于应用系统,Pushlets 为应用系统中的一个组件。
消息表管理组件提供消息新增,以及对推送过的消息记录的查询、删除。