websocket是什么?

一、定义

Websocket是一种在单个TCP连接上进行全双工通信的协议,它允许服务器主动向客户端推送数据,而不需要客户端不断的轮询服务器来获取数据

与http协议不同,http是一种无状态的,请求,响应模式的协议(单向通信),而websocket在建立连接后可以保持连接状态,实现双向通信

工作原理

建立连接,客户端向服务端发送一个http请求,请求包含Upgrade:websocket和connection:Upgrade字段,表示希望协议升级为websocket

如果服务器支持websocket,它会返回一个101Switchng Protocols的响应,然后双方就可以通过websocket协议进行通信了

二、在前端的应用

  1. 实时数据更新
    • 聊天应用:可以实现即时信息的发送和接受,无需不断的向服务器发请求来检查是否有新消息
    • 股票行情,体育赛事比分等实时数据的推送:服务器可以在数据发生变化时立即将新数据推送给客户端,用户可以及时看到最新消息
  2. 减少网络开销
  3. 由于不需要轮询那样频繁的发送http请求,减少网络带宽的占用和服务器的负载,例如,在一个实时监控系统中,使用websocket可以在有新事件发生时才进行数据传输,而不是每隔几秒就发送一次请求来检查是否有新事件

三、前端实现

  1. 使用原生 JavaScript
    • 浏览器提供了WebSocket对象来实现 Websocket 通信。例如:
    • 使用框架和库
      • 一些前端框架和库也提供了对 Websocket 的支持,例如 Vue.js 和 React.js 可以通过第三方库(如socket.io-client)来简化 Websocket 的使用。
相关推荐
洛水水23 分钟前
图床项目实现:MD5秒传 + 个人文件列表 + 图片分享等功能的完善
服务器·网络
Irissgwe33 分钟前
8-1\IP 分片和组装的具体过程
linux·网络·tcp/ip·网络层·分片·组装
闪电悠米1 小时前
黑马点评-秒杀优化-04_lua_and_db_fallback
服务器·开发语言·网络·数据库·缓存·junit·lua
Yang96111 小时前
风场光伏光缆分缆测损,DM-40A 光通信综合测试仪高效运维
网络·能源
努力搬砖的咸鱼1 小时前
容器编排底层原理:Kubernetes 网络模型与 CNI 插件
网络·微服务·云原生·容器·架构·kubernetes
ylscode1 小时前
Chrome桌面安全更新修复数百个漏洞
网络·windows·安全·安全威胁分析
.小小陈.1 小时前
从零构建可用 TCP 服务:从基础 Socket 到自定义协议与序列化
服务器·网络·tcp/ip
下北沢美食家1 小时前
WebSocket入门
网络·websocket·网络协议
zh路西法1 小时前
【rosbridge-websocket】跨网络的ROS1与ROS2通讯法(上)
linux·网络·c++·python·websocket·网络协议
梁辰兴1 小时前
计算机网络基础:电子邮件的信息格式
网络·计算机网络·电子邮件·计算机网络基础·梁辰兴·信息格式