WebSocket理解

简介: WebSocket理解

WebSocket

定义

本质上是TCP的协议

持久化的协议

实现了浏览器和服务器的全双工通信,能更好的节省服务器资源和带宽

与HTTP关系

相同点:

基于TCP协议,可靠性的传输协议

位于应用层

不同点:

WebSocket是双向通讯协议,而http是单向的

WebSocket需要浏览器和服务器握手进行建立连接,http浏览器发起向服务器连接,服务器预先是不知道的

联系

WebSocket在建立握手时,数据是通过http传输

WebSocket建立后,在真正传输数据时不需要http协议

总体过程

首先,当客户端发起http请求,经过3次握手后,建立TCP服务器收到客户端的握手请求后,

采用http协议回馈数据,客户端收到连接成功的消息后,开始借助TCP传输信进入全双工

HTTP问题

http是一种无状态协议,每当会话完成后,服务端都不知道下一个用户是谁,进而需要每次知道对方是谁,才能进行相应的响应

http请求采用一次请求,每次请求都会携带请求头,对于实时通讯每次请求解析请求头需要一定的时间,效率低

客户端主动发,服务端被动发,一次请求,一次响应,不能主动发送

长轮询

客户端发起长轮询,若服务端数据无变更,会hold住请求,直到服务端数据发生变更或一段时间后再进行下一次轮询

长轮询解决http不能实时更新的弊端,因为这个时间很短,发起请求即处理请求返回响应,实现了“伪·长连接”

它主要解决的就是推送延迟和服务器压力

推动延迟,服务端数据发生变更后,长轮询结束,立刻返回响应给客户端。

服务器压力,长轮询的间隔期一般很长,例如 30s、60s,并且服务端 hold 住连接不会消耗太多服务端资源。

Ajax轮询

定义:

规定每隔一段时间就由客户端发起一次请求,查询有没有新消息,如果有,就返回,如果没有等待相同的时间间隔再次询问

解决了http不能实时更新的弊端,因为这个时间很短,发起请求即处理请求返回响应,把这个过程放大n倍,本质上还是request = response

总的来说就是解决推送延迟、服务器压力、推送延迟和服务器压力无法中和

推送延迟

服务端压力

推送延迟和服务端压力无法中和,降低轮询的间隔,延迟降低,压力增加;增加轮询的间隔,压力降低,延迟增高

WebSocket特点

一旦WebSocket连接建立后,后续数据都以帧序列的形式传输。在客户端断开WebSocket连接或Server端中断连接前,不需要客户端和服务端重新发起连接请求。在海量并发及客户端与服务器交互负载流量大的情况下,极大的节省了网络带宽资源的消耗,有明显的性能优势,且客户端发送和接受消息是在同一个持久连接上发起,实现了“真·长链接”,实时性优势明显。

3cd5a68f4ad04541a8c122213442de5f.png

WebSocket有以下特点:

  • 是真正的全双工方式,建立连接后客户端与服务器端是完全平等的,可以互相主动请求。而HTTP长连接基于HTTP,是传统的客户端对服务器发起请求的模式。
  • HTTP长连接中,每次数据交换除了真正的数据部分外,服务器和客户端还要大量交换HTTP header,信息交换效率很低。Websocket协议通过第一个request建立了TCP连接之后,之后交换的数据都不需要发送 HTTP header就能交换数据,这显然和原有的HTTP协议有区别所以它需要对服务器和客户端都进行升级才能实现(主流浏览器都已支持HTML5)


相关文章
|
JSON 前端开发 JavaScript
解锁JSON的奇妙世界:从基础到高级应用,一文搞懂JSON的妙用(上)
解锁JSON的奇妙世界:从基础到高级应用,一文搞懂JSON的妙用(上)
411 0
解锁JSON的奇妙世界:从基础到高级应用,一文搞懂JSON的妙用(上)
|
存储 NoSQL 关系型数据库
现代数据库技术的发展与应用
本文将探讨现代数据库技术的发展趋势和广泛应用领域。我们将从传统关系型数据库开始,介绍NoSQL数据库、分布式数据库以及最新的图数据库等技术,探讨它们的特点和优势。此外,我们还将讨论数据库在大数据、云计算和物联网等领域中的应用案例,并展望未来数据库技术的发展方向。
|
存储 分布式计算 网络协议
大数据Spark Streaming入门
大数据Spark Streaming入门
314 1
|
消息中间件 弹性计算 数据可视化
SpringBoot 整合 Elastic Stack 最新版本(7.14.1)分布式日志解决方案,开源微服务全栈项目【有来商城】的日志落地实践
SpringBoot 整合 Elastic Stack 最新版本(7.14.1)分布式日志解决方案,开源微服务全栈项目【有来商城】的日志落地实践
|
机器学习/深度学习 虚拟化
|
JavaScript
VUE学习二:事件监听(v-on)、条件判断(v-if/v-else-if/v-else)、循环遍历(v-for)
这篇文章是关于Vue.js的学习指南,涵盖了事件监听、条件判断、循环遍历、数组方法响应性、案例分析以及高阶函数的使用。
198 2
VUE学习二:事件监听(v-on)、条件判断(v-if/v-else-if/v-else)、循环遍历(v-for)
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
291 4
|
Kubernetes 调度 Docker
Kubernetes(K8S) Pod 介绍
Kubernetes(K8S) Pod 介绍
357 0
|
负载均衡 Java 应用服务中间件
基于SpringBoot+Redis的前后端分离外卖项目-苍穹外卖(一)
基于SpringBoot+Redis的前后端分离外卖项目-苍穹外卖(一)
3015 0
|
算法
【图像】图像增强-降噪锐化
【图像】图像增强-降噪锐化
164 1