轮询(Polling)是指不管服务器端有没有更新,客户端(通常是指浏览器)都定时的发送请求进行查询,轮询的结果可能是服务器端有新的更新过来,也可能什么也没有,只是返回个空的信息。不管结果如何,客户端处理完后到下一个定时时间点将继续下一轮的轮询。

推送或叫长连接(Long-Polling)的服务其客户端是不做轮询的,客户端在发起一次请求后立即挂起,一直到服务器端有更新的时候,服务器才会主动推送信息到客户端。 在服务器端有更新并推送信息过来之前这个周期内,客户端不会有新的多余的请求发生,服务器端对此客户端也啥都不用干,只保留最基本的连接信息,一旦服务器有更新将推送给客户端,客户端将相应的做出处理,处理完后再重新发起下一轮请求。

举个例子:

轮询模式,假设是客户端每 2 秒轮询一次,那么客户端每 2 秒就会发送一次请求,相应的服务器端每 2 秒就要响应这个客户端的一次请求。而实际上服务器端可能 1 秒钟后就有更新,也可能 1 分钟后才有更新。对于 1 秒钟就有更新的,客户端至少会有 1 秒钟的延时;而 1 分钟后才有更新的,只有最后一次查询有意义,这一分钟内的轮询其实都是没有必要的,服务器端和客户端均有资源的浪费。

推送模式,客户端发送一次请求后马上挂起等待服务器端响应,可能 1 秒,也可能 10 秒钟,也可能 1 分钟。如果服务器端是 1 秒就有更新,那么到 1 秒钟时客户端马上就收到更新了,如果是 1 分钟才有更新,那么整个一分钟客户端也只请求一次,服务器也只会相应一次,这个就是和轮询的区别。