简单但全面了解一下webSocket

webSocket是一种协议,设计用于提供低延迟双全工长期运行的连接

**全双工:**通信的两个参与方可以同时发送和接收数据,不需要等待对方的响应或传输完成。双全工指的是一种通信方式,通过建立全双工的持久连接客户端和服务器之间就能实现高效实时性更强的通信。

什么是实时通信

传统通信: 电子邮件、网页浏览存在延迟,需要用户主动请求来获取更新数据。
实时通信: 即时消息传递(即时聊天)、音视频通话、在线会议和实时数据传输等,可以实现即时的数据传输和交流,不需要用户主动请求或刷新来获取更新数据。

webSocket之前的世界

在webSocket出现之前实现实时通信主要通过以下几种技术来解决:

  1. 轮询:客户端定期向服务器发送请求,询问是否有新的数据可以用服务器在接收到请求后再检查是否有更新的数据,并将其返回给客户端。
    缺点: 产生大量的请求和响应,导致不必要的网络开销和延迟。
  2. 长轮询: 在客户端发出请求后,服务器会保持连接打开一段时间,等待新数据响应后再关闭连接。是基于HTTP的技术
    优点:解决了无效轮询的数量
    缺点:需要频繁的建立和关闭连接
  3. Comet:Comet和长轮询一样是基于HTTP的技术,和长轮询不同的是它可以在返回请求后在返回请求后继续保持连接打开,它的核心思想就是通过保持长连接来模拟实时通信并允许服务器通过流式传输,iframe等推送技术来 主动向客户端推送数据,不过Comet虽然可以模拟实时通信但是它仍然是基于HTTP的模型,在Comet中服务器推送数据给客户端的方式通常还是通过延长响应或使用推送技巧来实现的。

webSocket的优势

总的来说,webSocket相比起其他的技术,有着以下这些优势:

  1. 双向实时通信
    允许在单个、长时间的连接上进行双向实时通信。需要在快速实时更新的应用程序里,比HTTP更加高效。WebSocket允许服务器主动向客户端推送数据,而不需要客户端发起请求。这种服务器推送的机制可以实现实时更新数据的功能,避免了客户端频繁地发送请求来获取最新数据的需求。

  2. 降低延迟
    webSocket的连接一旦建立便会保持开放,数据可以在客户端和服务器之间比HTTP更低的延迟进行传输。

  3. 更高效的资源利用
    可以减少重复请求和响应的开销,因为它的连接只需要建立一次。WebSocket在通信过程中的头部开销相对较小。HTTP协议每次请求都需要发送完整的头部信息,而WebSocket只需要在建立连接时发送一次头部信息,之后的通信只需要发送数据本身,减少了额外的开销。

  4. 二进制数据支持:
    WebSocket支持传输二进制数据,而HTTP协议主要用于传输文本数据。对于一些需要传输大量二进制数据的应用场景,WebSocket可以更高效地进行数据传输。

(这里补充一下HTTP协议:HTTP是一种无状态的协议,每次请求都需要建立一个新的连接,完成请求后立即关闭连接)
可以说webSocket的出现填补了传统的HTTP协议在实时通信方面的不足,它允许客户端和服务器之间通过单个TCP连接进行双工通信,并且进行实时的数据交换,所以webSocket的协议非常适用于基于Web的游戏、聊天应用以及任何低延迟实时连接的应用程序。目前的webSocket已经得到了主流浏览器的支持,而且由于webSocket的标准定义了一套通信规范,所以无论是JavaScript、Java还是其他编程语言都存在相应的库、框架或者模块来支持WebSocket的实现和使用,比如JS就有Socket.io。

那么要如何建立一个webSocket连接呢?
webSocket的建立需要通过HTTP发送一次常规的Get请求,并且在请求头中带上Upgrade,告诉服务器我想要从HTTP升级为WebSocket连接就建立成功了,之后客户端和服务器双方便可以随时向彼此发送信息。
在这里插入图片描述

在这里插入图片描述
后端部分用的node.js
先是引用了http和webSocket模块,先创建一个http实例,然后通过它再创建webSocket服务器,当有客户端连接到wenSocket服务器时就会触发Connection事件,当从客户端接收到消息时候会触发Message事件会接收一个参数表示从客户端那里接收到的消息内容
在这里插入图片描述

为什么需要心跳机制?

为了保持webSocket稳定的长连接,连接状态可能会因为各种原因发生变化,在连接建立之后,服务器和客户端之间通过心跳包来保持连接状态,以防止连接因为长连接没有数据传输而被切断。
心跳包就i是一种特殊的数据包,不包含任何实际数据,仅用来维持连接状态,通常情况下心跳包由客户端和服务器端定期发送一个空的数据帧,以确保双方的连接仍然有效,避免连接因为长时间没有数据传输而被中断,如果在一段时间内没有收到对方的心跳包就可以认为连接已经断开需要重新建立连接。

为什么发送空的数据帧就可以确保双方连接有效?

  1. 保持连接活跃:WebSocket连接在一段时间内没有数据传输时,可能会由于网络设备的超时机制或其他原因被关闭。通过定期发送空的数据帧,可以向服务器发送一个信号,告知连接仍然活跃,防止连接被关闭。

  2. 检测连接状态:发送心跳包可以帮助检测连接是否正常。如果客户端或服务器在一定时间内没有收到心跳包,就可以判断连接可能已经断开。这样可以及时采取措施,例如重新建立连接或通知用户连接中断。

  3. 节省带宽和资源:发送空的数据帧相比发送实际数据,可以减少数据传输的带宽消耗和服务器资源占用。心跳包通常只包含一些固定的控制信息,不需要传输大量的数据,因此可以降低网络负载和服务器负载。

  4. 快速检测连接中断:由于心跳包是定期发送的,一旦连接中断,客户端或服务器可以迅速发现连接断开的情况。这样可以更快地采取恢复措施,提高连接的可靠性和用户体验。

需要注意的是,心跳包的发送频率应根据具体应用的需求进行调整。发送过于频繁的心跳包可能会增加网络负载,而发送过于稀少的心跳包可能无法及时检测到连接中断。因此,需要根据实际情况选择合适的心跳包频率。

webSocket的限制

  1. 不提供加密功能
    如果有安全上的需求,需采用其他方式来确保安全性,如SSL协议对webSocket连接进行加密,防止敏感信息被窃听或者篡改,另外也可以限制访问的权限,在服务端设置黑名单或者白名单只允许特定IP地址或者域名的客户端进行连接。
  2. 不支持古老的浏览器
    不支持IE10以前的版本。需要使用AJAX或者其他方式来进行替代
  3. 优化很重要
    除此之外,当webSocket连接过多时可能会对服务器的性能造成负面影响,因为webSocket是一个长连接,需要服务器不断的维护和处理连接状态,优化性能。
  • 42
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 【小滴课堂】websocket入门到实战视课件是一门教授从基础到实际应用的WebSocket技术的课程。WebSocket是一种用于在客户端和服务器之间进行双向通信的协议,它允许实时的数据传输和即时通讯。这门课程的目的是帮助学员了解WebSocket的基本概念、原理和用法,并通过实战项目来巩固所学知识。 课程的第一部分是入门介绍,讲述了WebSocket的起源、发展和优势。学员将学会如何初始化和关闭WebSocket连接,了解WebSocket的生命周期和通信流程。 第二部分是WebSocket的基本概念和原理,包括握手过程、消息格式、心跳机制等。学员将学会如何通过WebSocket发送和接收消息,实现实时的双向通信。 第三部分是实战项目,通过一个实际的示例应用来演示WebSocket的使用。学员将学会搭建WebSocket服务器,处理不同类型的消息,实现群聊和私聊功能等。 课程的最后部分是课件,提供了学习WebSocket的详细文档和示例代码。学员可以随时查阅课件,复习和巩固所学内容。 通过【小滴课堂】websocket入门到实战视课件,学员可以系统地学习和掌握WebSocket技术,为实际项目的开发提供了很好的基础。无论是Web开发还是移动应用开发,WebSocket都是一项非常有用的技术,能够提供更好的用户体验和功能。 ### 回答2: 【小滴课堂】websocket入门到实战视课件是一门专注于教授websocket入门知识,并帮助学生通过实战视课件来巩固所学内容的在线课程。 websocket是一种在客户端和服务器之间建立持久连接的通信协议,它使得实时通信变得更加简单和高效。这门课程的目标是帮助学生理解websocket的基本概念和原理,并通过实际案例来实践使用websocket进行实时通信。 课程的内容安排从入门到实战的顺序来进行。在入门部分,课程会介绍websocket的基本概念、特点和用途,并演示如何在网页中使用websocket进行实时通信。学生将学习如何在服务端和客户端配置websocket连接,并使用websocket进行双向通信。 接下来的部分将介绍websocket中的高级概念和技术,例如消息传输格式、错误处理和安全性等。学生将学习如何处理不同类型的消息和错误,并了解如何保护websocket连接的安全性。 在实战部分,课程将提供一系列的视觉课件,其中包含了实际的项目案例和练习。学生将根据课件的指导,使用websocket技术来实现不同类型的实时通信功能。这些案例将涵盖多个领域,例如在线聊天室、实时数据展示和多媒体传输等。 通过这门课程,学生将掌握websocket的基本理论知识,了解如何配置和使用websocket进行实时通信,并能够通过实践项目来巩固所学内容。这将为学生提供一个深入了解websocket技术和应用的机会,并为未来的开发工作奠定坚实的基础。 ### 回答3: 小滴课堂的《websocket入门到实战》视课件是一套专门教授关于websocket相关知识的学习资料。本课程从入门到实战,系统地介绍了websocket的基本概念、原理、应用场景以及技术实现等方面的内容。 首先,课程通过准备章节,详细介绍了websocket的相关背景知识,包括Ajax、HTTP协议、长轮询等概念,为学员提供了对websocket的前置了解。 接着,课程着重讲解了websocket的基本原理和工作流程。学员可以通过课件了解websocket的握手过程、消息传递方式以及实现实时通信的原理等。课程还通过图示和实例代码,帮助学员深入理解websocket的相关概念和技术细节。 在实战部分,课件还提供了websocket的应用实例和具体开发案例。学员可以通过实践项目来巩固所学的知识。例如,通过编写一个在线聊天室的案例,学员能够实际运用websocket技术实现实时的双向通信,提升自己的技能和实践能力。 总体来说,小滴课堂的《websocket入门到实战》视课件是一份全面和系统的学习资料,适合想要学习websocket相关知识的开发者或初学者使用。课件内容生动明了,通过图解和实例代码等形式,将复杂的websocket技术转化为易于理解和实践的知识,帮助学员快速上手和掌握websocket的开发技能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值