Comet:HTTP长连接

2024-04-23 08:58
文章标签 连接 http comet

本文主要是介绍Comet:HTTP长连接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于 HTTP 长连接、无须在浏览器端安装插件的“服务器推”技术为“Comet”。


前提: http 1.1 + 基于目前web server的更改/额外的模块(插件)

 

概念
     关于comet的最初定义来自这篇blog文章:http://alex.dojotoolkit.org/?p=545。
     简单的说就是客户端发送一个请求,服务器接收它,并使用一个无限循环,将客户端需要的数据push到response中,并进行刷新,但是该response并不关闭,继续接收新的数据并刷新,直到客户端断开连接,该循环才结束退出。
     我们可以认为ajax解决了单用户响应的问题,而comet则解决了在保证性能的前提下进行协同多用户的响应问题。
     comet的优点在于它可以在任何时候向客户端发送数据,而不仅仅只是响应用户的输入请求。而发送数据是在一个已有的单连接上进行的。因此可以大大降低发送数据的延迟时间(建立connection的开销,以及客户端发送请求的等待时间)。

 

关于Event Web Server
     comet技术的一个重要组成部分就是event-drived web server,目前商用的实现已经出现,如lightstreamer(http://www.lightstreamer.com),这个我没有仔细看,只是跑了一下他给出的demo,还行!开源的实现就是apache+jetty(还要加一个mod)这个我还没有具体用过!

     有国人声称实现了comet server(http://cnc.agile.com/read.php?tid=319),还没去仔细研究,不知道如何。

      pushlet目前使用的是client pull做法,当然它的server push也将在不久的将来实现,它没有声称只能在专用的event-drived web server上运行,目前在tomcat运行环境下是可以的,不知道最多能承受多少用户同时访问还有待考证!

comet新体验
      我看了一下comet技术的一些实现,其中meebo(http://wwwm.meebo.com/)算是做的比较好的一个(gmail有谁用过?说说感受),我觉得它的web版本msn messager,比微软自己的web msn就要好用的多。
     
     
基于http的聊天类应用,自始自终都只有两类做法(如果有其他类别,请指正我),
1.client pull。用JS等定时去服务器取数据。
  好处是保持了http server的无状态高并发,坏处是大量的pull动作其实是白费的。
2.server push。服务端的JSP等程序的响应永不关闭,定时输出新内容。
  好处是有新内容才输出,比较节省带宽等资源,坏处是长期占用了连接,丧失了无状态高并发的特点。
连接时有状态长期保持还是相反,这个也是传统意义上C/S与B/S的一大区别。所以看上去C/S会比B/S的并发负载能力低。但C/S的响应会更灵活和快速。

 

server push通过维持长连接来得到快速将数据push到所有已连接的客户端,正因为如此所以不能采用传统的http web server,必须使用专用的event-drived web server来解决keep-alived connection的问题。


所以comet也没有什么新技术,一个成熟的comet应用除了需要一定的客户端脚本和服务器端代码的支持还需要特定的web server的支持!而一个成熟的comet framework则需要对这些客户端脚本和服务器代码进行良好的封装并能与各种event-drived web server能进行很好的结合,目前还没有比较成熟的event-drived web server出现,因此comet应用也没有象ajax那样普及。
与ajax应用相比,comet技术主要适用于即时通讯,实时数据监控,多用户协同交互的系统,所以comet应该算是ajax的一个有力补充和延伸!      
请求得不到服务器的response 所以连接时一直保持的 除非超时。


comet(http 请求长连接) 之 ajax 长查询 简单实现
http://www.cnblogs.com/leon_yang/archive/2009/10/10/1580247.html

HTTP长连接服务器端推技术
http://blog.csdn.net/starxu85/archive/2008/11/23/3356907.aspx

Comet:基于 HTTP 长连接的“服务器推”技术
http://www.cnblogs.com/happyday56/archive/2009/06/10/1500427.html
http://www.ibm.com/developerworks/cn/web/wa-lo-comet/


Nginx加Comet:低延迟的服务器端推送
http://www.jifuyi.com/nginx-and-comet-low-latency-server-push/


http://www.blogjava.net/rosen/archive/2009/02/11/254309.html


如何在 Tomcat 6 中实现异步 Servlet
http://tomcat.apache.org/tomcat-6.0-doc/aio.html

 

浅谈comet技术

http://hi.baidu.com/zjugis/blog/item/cbaaaa642e65d9f8f736541d.html

Comet登 场,简单说还是利用Ajax与服务器建立http长连接查询是否有数据更新,服务器收到一个连接如果没有数据更新就阻塞这个连接不要返回给客户端,直到有 新数据再返回给客户端。Web客户端,发起的连接一旦被返回,或者超时就再次建立http长连接。这样就能保证数据的即时更新,以及尽量减少服务器的计算 工作。 2. Comet的一些应用

目前Comet主要应用在一些股票web客户端,以及一些基于web的即时聊天系统中。

 

比较成熟的框架有Dojo ,Dwr 等一些Ajax框架中实现了该功能。
3. Comet 优、 缺点

3.1 缺点  

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

server push不会是一个没有副作用的解决方案,是否适合还要仔细权衡。

3.2 优点  

Ø 实时性好(消息延时小)

Ø 性能好(能支持大量用户)
4.其他服务器推技术

Comet 只是众多服务器推技术中的一种,目前市面上还有许多其他流行服务器推技术。
4.1 Flash XMLSocket

这种方案实现的基础是:

1. Flash 提供了 XMLSocket 类。

2. JavaScript 和 Flash 的紧密结合:在 JavaScript 可以直接调用 Flash 程序提供的接口。

但此方案的缺点在于:

1. 因为 XMLSocket 没有 HTTP 隧道功能,XMLSocket 类不能自动穿过防火墙;

2. 因为是使用套接口,需要设置一个通信端口,防火墙、代理服务器也可能对非 HTTP 通道端口进行限制;

不过这种方案在一些网络聊天室,网络互动游戏中已得到广泛使

4.2 Java Applet 套接口

在客户端使用 Java Applet,通过 java.net.Socket java.net.DatagramSocket java.net.MulticastSocket 建立与服务器端的套接口连接,从而实现“服务器推”。

这种方案最大的不足在于 Java applet 需要客户端安装JAVA虚拟机

这篇关于Comet:HTTP长连接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/928349

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

java如何通过Kerberos认证方式连接hive

《java如何通过Kerberos认证方式连接hive》该文主要介绍了如何在数据源管理功能中适配不同数据源(如MySQL、PostgreSQL和Hive),特别是如何在SpringBoot3框架下通过... 目录Java实现Kerberos认证主要方法依赖示例续期连接hive遇到的问题分析解决方式扩展思考总

Python中连接不同数据库的方法总结

《Python中连接不同数据库的方法总结》在数据驱动的现代应用开发中,Python凭借其丰富的库和强大的生态系统,成为连接各种数据库的理想编程语言,下面我们就来看看如何使用Python实现连接常用的几... 目录一、连接mysql数据库二、连接PostgreSQL数据库三、连接SQLite数据库四、连接Mo

oracle如何连接登陆SYS账号

《oracle如何连接登陆SYS账号》在Navicat12中连接Oracle11g的SYS用户时,如果设置了新密码但连接失败,可能是因为需要以SYSDBA或SYSOPER角色连接,解决方法是确保在连接... 目录oracle连接登陆NmOtMSYS账号工具问题解决SYS用户总结oracle连接登陆SYS账号

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

Xshell远程连接失败以及解决方案

《Xshell远程连接失败以及解决方案》本文介绍了在Windows11家庭版和CentOS系统中解决Xshell无法连接远程服务器问题的步骤,在Windows11家庭版中,需要通过设置添加SSH功能并... 目录一.问题描述二.原因分析及解决办法2.1添加ssh功能2.2 在Windows中开启ssh服务2

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re