PHP ServerPush (推送) 技术

用来代替ajax的请求php

转自:http://blog.163.com/bailin_li/blog/static/17449017920124811524364/html

需求:前端

我想作个会员站内通知的功能。不想用之前的ajax查询,据说有个推技术。如下文章介绍的不错,来自转载,html5

==================================================================================
node

PHP中Push(推送)技术的探讨  [http://vistaswx.com/blog/article/php-server-push]jquery

 

随着人们对Web即时应用需求的不断上升,Server Push(推送)技术在聊天、消息提醒尤为是社交网络等方面开始兴起,成为实时应用的数据流核心。这篇日志试图探讨的即是各类适合于PHP的Push的实现方式以及其优劣。web

1. 什么是Server Pushajax

想象在聊天应用中,若是使用传统的ajax来承担消息的传入,那么通常是经过每隔必定时间拉取一次信息的方式实现,可是其实这种方式有大量查询是浪费的。聊天等Web应用更须要服务器在特定时间来主动告知前端有新的消息(Push),而不是前端每时每刻问服务器:“来消息了吗?”(Pull)。这也正是为何这个技术常被叫作反向ajax。跨域

其余别名:Comet,反向Ajax浏览器

 

2. 如何实现Push

其实所谓的推送技术也没有多么复杂,目前从大类上有3种,一种仍然创建在ajax基础上,还有一种创建在框架基础上,最后一种抛弃了传统的HTTP协议,使用Flash或者HTML5的WebSockets技术。接下来将对这三种类别产生的不一样的方式进行探讨。

1) Ajax 长轮询

Ajax长轮询从本质上来讲仍然是一种pull,可是实时性较高,无用请求减小不少,是一种不错的Push实现方案。不过它只减小了网络上的无谓消耗。

核心: 客户端发起一个ajax请求,服务端将请求搁置(pending)或者说挂起,直到到了超时时间(timeout)或须要推送时返回;客户端则等待ajax返回后处理数据,再发起下一个ajax请求。

优势: 兼容性较高,实现简单

缺点: 对于php这种语言来讲,若是要作到实时,那么服务端就要承受大得多的压力,由于搁置到何时每每是不肯定的,这就要php脚本每次搁置都进行一个while循环。
固然,若是服务器刷新每秒级,那尚可接受,只是实时性上退化了。

注意: 浏览器有链接数限制。我得出的结论是若是当前页面上有一个ajax请求处于等待返回状态,那么其余ajax请求都会被搁置(Chrome, Firefox已测)。若是页面有通常ajax需求怎么办?解决方法是开个框架,框架中使在另外一个域名下进行Comet长轮询,须要注意跨域问题。

PHP实现: Jquery+php实现comet

相关:Ajax跨域和js跨域解决方案

 

2) Frame 长链接

受到ajax启发,出现了框架下的长链接。

核心: Frame中发起一个普通请求,服务器将其搁置;须要推送时输出直接执行
脚本,而后继续保持链接。若是担忧超时问题能够改为框架论询。

优势: 与1同样具备高兼容特性

缺点: 最大的问题是若是框架在载入,那么浏览器就好一直显示“载入中”,这就弱爆了(解决方法参见文末的相关阅读资源)。一样服务器也要能hold住大量循环……另外,是否有同域链接限制没测试。

 

 

3) Flash/HTML5 WebSockets

用flash来发起WebSockets,秒杀前面一切问题。

优势: 标准化, RealTime, Push

缺点: 服务器须要能应对WebSockets;还有若是既没有Flash又不支持HTML5的怎么办?

PHP实现: Start Using HTML5 WebSockets Today

 

6) 使用兼容封装层(socket.io)

以上每种方法都有优劣,那么终极解决方案即是合在一块儿!能WebSockets时候就WebSockets,不支持HTML5特性就退化到Flash,没有Flash则退化到Ajax长轮询。这也是个人Rainbowfish所采用的方式。

优势: 高度封装,编写很是容易,几乎不须要关心如何去实现的。实时,超低负载,高并发。

缺点: 其实算不上缺点,socket.io的服务器端要求是node.js,而不是php。

我的见解: 若是你是独立主机,能运行程序,那么socket.io配合node.js是个很是高效的选择。为何呢?由于它还能够避免php的服务端高负载。

Rainbowfish的消息系统经过这种方式实现: 全部客户端都经过socket.io挂在nodejs服务器上(注意: 只是挂着,不须要任何循环,由于它是事件驱动的);须要推送消息了,服务器就与nodejs通讯(好比访问某个地址来实现),告诉它推送什么消息到哪里;nodejs收到推送信号后,则经过socket.io实时传输数据给浏览器。这个其实也是一条单向的路,由于nodejs服务器不具有与php通讯的能力,实际上也不须要,网页上直接连php就能够了。

 

3. 结束语

事实上,第一个方法(Ajax Long Pull)是一个不错的方法,只是若是使用php完成的话服务器负载上有点大,但这实际上是通病;而最后列举的socket.io方案彻底避免了这个问题,由于它属于另外一种架构,而且这种组合也能够配合几乎全部的脚本语言实现push。

对于实时性要求很是高的应用,或许使用php实现实时部分并非一个好的选择,将会面临很是大的服务器负载(能够经过编写支持等待事件的扩展来解决这个问题);若是只是消息提示等,则能够调整服务器上刷新的间隔下降到秒的级别,负载尚可接受。不过不管哪一种用途,配合那些非阻塞语言或许才是最好的选择。

4. 相关阅读

How to implement COMET with PHP

Start Using HTML5 WebSockets Today

Comet(Wikipedia)

Ajax跨域和js跨域解决方案

Jquery+php实现comet

==============================================================================================

 

comet研究[http://lync.in/research-on-comet/]

 

在Web应用中,客户端的AJAX技术已经很是广泛也很是深刻人心了,但与此同时,另外一些应用,诸如在线监控,实时数据显示,即时通信等须要将后台数据变化状况实时显示到前台,这样的由服务器push的行为(也许会让你想到blackberry)则须要另外一种方案来解决,也就是本文所要介绍的Comet —— 无需安装插件,保持http长链接的服务器推方案。
如下两点是方案中必须顾及到的。

  1. 浏览器通用性,对各类不一样实现结构模型的支持。
  2. 长链接对于服务器资源的占用,以及服务器的承受能力

Comet的客户端与服务端交互流

业界对于Comet实现有两种主要的解决方案:

  1. 基于AJAX的轮询(long polling)方式

    这种方式就是由客户端发出AJAX请求,而后服务端阻塞请求直至有响应或超时。客户端在接收到服务端的指令以后会进行响应并发出新的请求。

    从实现层面上来讲,当XMLHttpRequest的状态为4也就是load的状态时会进行客户端处理,而Gecko(Firefox)和Webkit(Chrome,Safari)目前支持在readystate为3的时候读取(固然只能读取到全部该请求已返回的串内容,因此须要自行肯定指令边界),Trident(IE)目前若是中途去读取会抛出错误,IE8中使用XDomainRequest能够适当解决这个问题(参见Eric Law的COMET Streaming in Internet Explorer[])。

    目前,开心网采用的是这一种方式。

  1.  
  2. 基于iframe及htmlfile的流(streaming)方式

    这种方式是使用了iframe的机制,而后使得这个iframe请求一个特定的URL,并经过对这个页面的加载不断的从服务端抓回数据,这里从服务端抓回的数据大可能是对页面当前JavaScript函数的引用和操做。

    这个方案的一个明显不足之处是页面会一直显示正在加载,而这在IE上会更明显。Google的天才们想到了用htmlfile的ActiveX控件来解决这个问题的方案,详细描述能够参见Alex Russell的What else is burried down in the depth's of Google's amazing JavaScript?

    目前,人人网和GTalk采用的是这种方式。

除了文首所提到的通用性和性能以外,还有几点是须要列入考量范围的。

  1. 数据交换的格式。因为数据交换的形式是推送,因此不可避免的会有指令队列的存在,因而数据结构是须要先后台详细约定的,执行指令和数据指令都须要有严格的界定,通常来讲,JSON的方案比较广泛。
  2. 浏览器自己的链接数限制。HTTP 1.1规范中声明客户端不该该与服务器端创建超过两个的 HTTP 链接,而IE又严格遵照了这一点,因此前台在处理请求的时候须要谨慎控制请求的数量。

其实,Comet技术在AJAX大红大紫的2005年以后的2006年时是业界一个很热的讨论点,目前的这两种方式很是成熟,在dojo,dwr等前端框架中都已经有这样的实现,而Bayeux协议的出现也已经在实质上订下了一种业界的标准。

Comet的框架前端有Pushlet,dwr和dojo等,服务端有Jetty,Meteor,Orbited,Glassfish,Alpha,实现的产品语言也覆盖了Java,C++,Python,Perl,Ruby,Erlang,.Net等。

下一代HTML5中的WebSocket会是Comet的一个新起点,但在那以前,在非插件的web层面应该不会有更进一步的讨论与技术出现。

本文只是对Comet这个技术进行大致的概述,粗陋不明之处不免,在后续的文章中将会对WebSocket进行必定的解释和演示。

参考资料:

  • 这里有一个php的comet的例子How to implement COMET with PHP。这个要看看
  • 这是developerWorks上对于Comet的介绍
  • 这是当前Comet的服务器端的一些产品及介绍
  • 固然,Wikipedia上面对Comet的解释也是很是详尽。
  • 还能够看看AjaxPatterns上面的一些介绍
  • 最后,CometDaily是个值得去了解最新Comet新闻和知识的地方。
  • =====================================================================================================

Comet:基于 HTTP 长链接的“服务器推”技术

  [http://www.ibm.com/developerworks/cn/web/wa-lo-comet/]

ps:上述文章应该够你看明白的了。使用一种吧。但我如今尚未在项目用推技术,缘由,尚未来得及折腾,但在本地测试都很正常 。

如下提供protype 和 jquery的 +php实现的代码例子。[例子代码来自网上,已测试经过。好用]

http://bbs.php100.com/read-htm-tid-290215-ds-1.html

相关文章
相关标签/搜索