面试之《websocket》

配置环境

shell 复制代码
mkdir express
cd express
npm init
npm install express ws
javascript 复制代码
// index.js
var app = require("express")();
var WebSocket = require("ws");

var wss = new WebSocket.Server({ port: 8888  });

wss.on('connection', function connection(ws) {
  ws.on('message', function incoming(message) {
    console.log('received: %s', message);
  });

  ws.send('something');
});

app.get("/", function(req, res) {
  res.sendFile(__dirname + "/index.html");
});

app.listen(4000, function() {
  console.log("Server is running on port 4000")
})
html 复制代码
// index.html
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <h1>Hello</h1>
  <p>WebSocket</p>
  <button id="btn" onclick="ws.send('from client: click')">click</button>

  <script>
    var ws = new WebSocket('ws://localhost:8888');
    ws.onopen = function () {
      console.log('ws onopen');
      ws.send('from client: hello');
    };
    ws.onmessage = function (e) {
      console.log('ws onmessage');
      console.log('from server: ' + e.data);
    };
  </script>
</body>

</html>


页面初始化事,就发送hello至ws,ws接收到后,返回"你好!"

简单实现了ws的交互。

下面介绍一下ws的相关知识点:

1. 基础概念

  • 定义:WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,它允许客户端和服务器之间进行实时、双向的数据传输。
  • 诞生背景:传统的 HTTP 协议是无状态、单向的,每次通信都需要建立新的连接,无法满足实时通信的需求,WebSocket 应运而生。

2. 工作原理

  • 握手阶段 :客户端发起一个 HTTP 请求,请求头中包含特殊的升级字段(Upgrade: websocketConnection: Upgrade),服务器收到请求后,如果支持 WebSocket 协议,就会返回一个状态码为 101 的响应,表示同意升级协议,之后双方就可以在这个 TCP 连接上进行 WebSocket 通信。
  • 数据传输:在建立连接后,客户端和服务器可以随时向对方发送数据,数据以帧的形式进行传输。

3. 使用场景

  • 实时聊天应用:如在线客服、即时通讯软件等,能实现消息的即时推送和接收。
  • 实时数据展示:如股票行情、体育赛事比分等,数据的变化能及时更新到客户端。
  • 多人游戏:玩家之间的操作和状态可以实时同步。

4. 优缺点

  • 优点
    • 实时性强:数据可以即时传输,无需频繁建立连接。
    • 减少开销:相比于 HTTP 长轮询和短轮询,减少了不必要的请求和响应头,降低了服务器和客户端的负担。
    • 全双工通信:客户端和服务器可以同时发送和接收数据。
  • 缺点
    • 兼容性问题:一些旧版本的浏览器可能不支持 WebSocket 协议。
    • 安全性要求高:需要注意防止中间人攻击和数据泄露。

5. 与其他协议对比

  • 与 HTTP 对比
    • HTTP 是无状态、单向的,每次请求都需要建立新的连接;WebSocket 是有状态、全双工的,建立连接后可以持续通信。
    • HTTP 适用于一次性的请求 - 响应场景;WebSocket 适用于实时通信场景。
  • 与 HTTP 长轮询对比
    • HTTP 长轮询是客户端发送请求后,服务器保持连接直到有新数据才返回响应,然后客户端再重新发起请求;WebSocket 是建立一次连接后可以持续双向通信。
    • HTTP 长轮询在服务器没有新数据时也会占用连接资源,而 WebSocket 只有在有数据传输时才会占用带宽。
相关推荐
YuMiao3 天前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
Jony_6 天前
高可用移动网络连接
网络协议
chilix6 天前
Linux 跨网段路由转发配置
网络协议
DianSan_ERP8 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
呉師傅8 天前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
gihigo19988 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
2501_946205528 天前
晶圆机器人双臂怎么选型?适配2-12寸晶圆的末端效应器有哪些?
服务器·网络·机器人
linux kernel8 天前
第七部分:高级IO
服务器·网络
数字护盾(和中)8 天前
BAS+ATT&CK:企业主动防御的黄金组合
服务器·网络·数据库
~远在太平洋~8 天前
Debian系统如何删除多余的kernel
linux·网络·debian