目录

长连接与短连接

长连接与短连接

轮询与连接简介

  • 轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接。 优点:后端程序编写比较容易。 缺点:请求中有大半是无用,浪费带宽和服务器资源。 实例:适于小型应用。

  • 长轮询:客户端向服务器发送Ajax请求,服务器接到请求后hold住连接,直到有新消息才返回响应信息并关闭连接,客户端处理完响应信息后再向服务器发送新的请求。 优点:在无消息的情况下不会频繁的请求,耗费资源小。 缺点:服务器hold连接会消耗资源,返回数据顺序无保证,难于管理维护。 实例:WebQQ、Hi网页版、Facebook IM。

  • 长连接:在页面里嵌入一个隐蔵iframe,将这个隐蔵iframe的src属性设为对一个长连接的请求或是采用xhr请求,服务器端就能源源不断地往客户端输入数据。 优点:消息即时到达,不发无用请求;管理起来也相对方便。 缺点:服务器维护一个长连接会增加开销。 实例:Gmail聊天

关于长轮询

长轮询实际上就是一个普通额的http请求,但是并不会立刻返回消息,而且等待服务器处理,这中间并不断开连接,而是保持着,直到服务器响应客户端。

关于使用redis进行阻塞实现长轮询。

1
2
3
4
5
6
7
8
9
        @app.route('/getPic',methods = ['GET'])
        def getPic():
            redis = self.task.redis
            rep ={
                'status':'no qrcode',
                'content':None
            }
            if redis.llen('taskQueue') == 0: # 一个都没有则等待并阻塞
                item = redis.blpop('taskQueue', timeout=30) # 因为返回的是元组

redis的队列pop有阻塞作用,可以维持住请求,实现长轮询。