码迷,mamicode.com
首页 > Web开发 > 详细

WebSocket

时间:2020-05-19 20:44:42      阅读:54      评论:0      收藏:0      [点我收藏+]

标签:网络协议   改进   应用   soc   实时web   pid   enc   point   bean   

一  概念   什么是WebSocket

WebSocket协议是基于TCP的一种新的网络协议。随着HTML5的诞生,WebSocket协议被提出,它实现了浏览器与服务器全双工(full-duplex)通信——允许服务器主动发送信息给客户端。

技术图片

 

与传统HTTP协议做对比

  传统的HTTP协议是无状态的,每次请求(request)都要由客户端(如浏览器)主动发起,服务端进行处理后应道(response)结果,而服务端很难主动向客户端发送数据。

这种客户端是主动方,服务端是被动方的Web模式,对应信息变化不频繁的Web应用来说影响不大,而对于涉及实时信息的Web应用却带来了很大的不便,

如 即时通信,实时数据,订阅消息推送等功能的应用。 所以开发人员要实现实时性比较强的功能,经常要使用折中的解决方法: 轮询(polling)和 Comet(也称反向Ajax或服务器端推技术)

其实  Comet 本质上也是一种轮询,只不过有所改进

 

轮询 是最原始的实现实时Web应用的解决方案。轮询技术要求客户端以设定的时间间隔周期性地向服务端发送请求,频繁地查询是否有新的数据改动。明显地,这种方法会导致过多不必要的请求,浪费流量和服务器资源。

Comet 技术又可以分为长轮询和流技术。长轮询改进了上述的轮询技术,减小了无用的请求。它会为某些数据设定过期时间,当数据过期后才会向服务端发送请求;这种机制适合数据的改动不是特别频繁的情况。流技术通常是指客户端使用一个隐藏的窗口与服务端建立一个HTTP长连接,服务端会不断更新连接状态以保持HTTP长连接存活;这样的话,服务端就可以通过这条长连接主动将数据发送给客户端;流技术在大并发环境下,可能会考验到服务端的性能。

 这两种技术都是基于请求-应答模式,都不算是真正意义上的实时技术;它们的每一次请求、应答,都浪费了一定流量在相同的头部信息上,并且开发复杂度也较大。

 

伴随着HTML5推出的WebSocket,真正实现了Web的实时通信,使B/S模式具备了C/S模式的实时通信能力。WebSocket的工作流程是这 样的:浏览器通过JavaScript向服务端发出建立WebSocket连接的请求,在WebSocket连接建立成功后,客户端和服务端就可以通过 TCP连接传输数据。因为WebSocket连接本质上是TCP连接,不需要每次传输都带上重复的头部数据,所以它的数据传输量比轮询和Comet技术小 了很多。本文不详细地介绍WebSocket规范,主要介绍下WebSocket在Java Web中的实现。

 

二  WebSocket 示例

服务端实现

首先加入pom依赖

<dependency>  
           <groupId>org.springframework.boot</groupId>  
           <artifactId>spring-boot-starter-websocket</artifactId>  
</dependency> 

 

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.socket.server.standard.ServerEndpointExporter;

/**
 * 开启WebSocket支持
 * @author zhengkai.blog.csdn.net
 */
@Configuration  
public class WebSocketConfig {  
    
    @Bean  
    public ServerEndpointExporter serverEndpointExporter() {  
        return new ServerEndpointExporter();  
    }  
  
}

 

WebSocket

标签:网络协议   改进   应用   soc   实时web   pid   enc   point   bean   

原文地址:https://www.cnblogs.com/hup666/p/12918914.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!