基于ASP.NET的Comet长连接技术解析

2015-01-30 来源:未知作者:admin

Comet技术原理

来自维基百科:Comet是一种用于web的技术,能使服务器能实时地将更新的信息传送到客户端,而无须客户端发出请求,目前有两种实现方式,长轮询和iframe流。

简单的说是一种基于现有Http协议基础上的长轮询技术,之所有会产生这种技术的主要原因是Http协议是无状态的所以客户端和服务端之间没办法建立起一套长时间的连接。比如我们要做一个聊天室,在Web环境下我们通常不能从服务端推送消息到浏览器里,而只能通过每个客户端不断的轮询服务器,以获取最新的消息,这样一来效率非常低,而且不断的向服务器发送请求对于访问量大的应用来说也会造成很大的资源占用。

于是人们就发现了这种技术,向服务器发起一个请求,然后服务器一直不响应这个请求,这样客户端和服务端之间就形成了一个长连接,直到服务端响应这个请求后结束本次连接。借用一下IBM里的图片:

\

通过Ajax技术可以实现长轮询的服务器推模型,客户端和服务端之间通过不断的发起长轮询即可以实现数据的交互,这个过程由于是Ajax实现的异步操作所以体验上会比较好,效率也很高。哎呀呀,说不清楚,找个网上的资料:

Comet方式通俗的说就是一种长连接机制(long lived http)。同样是由Browser端主动发起请求,但是Server端以一种似乎非常慢的响应方式给出回答。这样在这个期间内,服务器端可以使用同一个connection把要更新的数据主动发送给Browser。因此请求可能等待较长的时间,期间没有任何数据返回,但是一旦有了新的数据,它将立即被发送到客户机。Comet又有很多种实现方式,但是总的来说对Server端的负载都会有增加.虽然对于单位操作来说,每次只需要建议一次connection,但是由于connection是保持较长时间的,对于 server端的资源的占用要有所增加。

优点: 实时性好(消息延时小);性能好(能支持大量用户)

缺点: 长期占用连接,丧失了无状态高并发的特点。

应用: 股票系统、实时通讯。

参考资料:

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

基于Asp.Net的实现Comet的技术基础