Netty Websocket

一、WebSocket 协议概述

WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。它允许服务端主动向客户端推送数据,从而实现了实时通信。WebSocket 建立在 HTTP 之上,但与 HTTP 的轮询(Polling)和长轮询(Long Polling)相比,WebSocket 只需一次握手,即可在客户端和服务器之间建立持久的连接,并通过这个连接进行双向数据传输。

二、Netty 框架简介

Netty 是一个高性能、异步事件驱动的网络应用程序框架,支持快速开发可维护的高性能协议服务器和客户端。它基于 Java NIO(非阻塞 I/O)进行封装,提供了更简单易用的 API,并解决了 NIO 编程中常见的复杂性和错误。

三、Netty WebSocket 原理

1. 握手过程

  • 客户端发起握手请求:客户端通过 HTTP 请求与服务器建立 WebSocket 连接。这个请求与普通的 HTTP 请求不同,它包含了 WebSocket 特有的升级请求头(如 Upgrade: websocket 和 Connection: Upgrade),以及一个用于验证的 Sec-WebSocket-Key。
  • 服务器响应握手请求:服务器接收到客户端的握手请求后,会解析这些请求头,并生成一个响应。响应中包含了 Sec-WebSocket-Accept 头,该头的值是使用 Sec-WebSocket-Key 加上一个固定的字符串(如 “258EAFA5-E914-47DA-95CA-C5AB0DC85B11”),然后通过 SHA-1 加密并 Base64 编码得到的。如果服务器同意升级协议,则响应的状态码为 101(Switching Protocols)。
  • 握手成功:一旦服务器发送了包含 Sec-WebSocket-Accept 的响应,并且客户端验证了该响应的正确性,WebSocket 连接就建立起来了。此时,客户端和服务器之间就可以通过 TCP 连接进行双向数据交换了。

2. 数据传输

  • 帧(Frame):在 WebSocket 协议中,数据是通过帧来传输的。一个帧可以包含文本数据、二进制数据或控制帧(如关闭帧)。
  • ChannelHandler:Netty 使用 ChannelHandler 来处理网络事件和数据。在 WebSocket 应用中,通常会定义一系列的 ChannelHandler 来处理 WebSocket 的特定事件,如握手、消息接收、消息发送等。
  • ChannelPipeline:Netty 使用 ChannelPipeline 来管理 ChannelHandler 的链式调用。每个 Handler 都可以对经过的数据或事件进行处理,并决定是否将其传递给链中的下一个 Handler。

3. Netty 的线程模型

  • EventLoopGroup:Netty 使用 EventLoopGroup 来管理一组 EventLoop。每个 EventLoop 都是一个不断循环执行任务的线程。在 WebSocket 服务器中,通常会使用两个 EventLoopGroup:一个是用于接收客户端连接的 BossGroup,另一个是用于处理网络读写的 WorkerGroup。
  • ChannelPipeline 中的处理流程:当数据到达时,Netty 会将其封装成一个 ChannelHandlerContext 对象,并在 ChannelPipeline 中传递。每个 ChannelHandler 都可以对这个对象进行处理,并可以决定是否将其传递给链中的下一个 Handler。

四、Netty WebSocket 的优势

  • 高性能:Netty 基于 NIO 进行封装,提供了非阻塞的 I/O 操作,能够处理大量的并发连接。
  • 易用性:Netty 提供了丰富的编码解码器和 Handler,使得开发者可以很容易地实现 WebSocket 的功能。
  • 稳定性:Netty 在稳定性和故障恢复方面有出色的表现,能够确保 WebSocket 连接的稳定性和可靠性。

五、Netty WebSocket 的主要组成部分

  1. ChannelHandler:Netty 使用 ChannelHandler 来处理网络事件,如连接建立、数据读写等。在 WebSocket 应用中,你会定义一系列的 ChannelHandler 来处理 WebSocket 的特定事件,如握手(Handshake)、消息接收、消息发送等。
  2. ChannelPipeline:Netty 使用 ChannelPipeline 来管理 ChannelHandler 的链式调用。你可以将多个 ChannelHandler 添加到同一个 ChannelPipeline 中,每个 Handler 都可以对经过的数据或事件进行处理,并决定是否将其传递给链中的下一个 Handler。
  3. WebSocketServerProtocolHandler:这是 Netty 提供的专门用于处理 WebSocket 协议的 Handler。它负责处理 WebSocket 的握手请求,并在握手成功后将后续的 HTTP 帧转换为 WebSocket 帧。
  4. WebSocketVersionWebSocketSubprotocol:Netty 允许你指定 WebSocket 的版本(如 RFC6455, 也就是 WebSocket 1.0)以及子协议(如自定义的协议标识符)。

六、Netty WebSocket 应用场景

Netty WebSocket 的应用场景非常广泛,主要集中在需要实时、双向通信的 web 应用中。以下是一些典型的应用场景:

1. 即时聊天

  • 应用描述:构建实时聊天应用,用户可以实时发送和接收消息,实现低延迟、高效的在线交流。
  • 优势:WebSocket 提供了持久连接和双向通信的能力,使得聊天应用能够实时传输消息,减少延迟,提升用户体验。

2. 金融市场实时数据推送

  • 应用描述:股票、外汇、期货等金融市场的实时报价、交易提醒等。
  • 优势:金融市场数据变化迅速,WebSocket 能够实现服务器主动推送数据给客户端,确保用户能够实时获取最新的市场动态。

3. 新闻与社交媒体实时推送

  • 应用描述:新闻、社交媒体的实时推送通知,如微博、今日头条等平台的实时更新。
  • 优势:通过 WebSocket,新闻和社交媒体平台可以实时向用户推送最新的内容,提高用户粘性和活跃度。

4. 物联网(IoT)设备监控与远程控制

  • 应用描述:智能家居、工业自动化等物联网设备的状态监控与远程控制。
  • 优势:物联网设备通常需要实时上传数据并接收控制指令,WebSocket 的实时性和双向通信能力使其成为物联网通信的理想选择。

5. 协作工具

  • 应用描述:在线文档编辑、白板绘图、代码协作等需要多方实时同步内容的应用。
  • 优势:协作工具需要实时共享和同步数据,WebSocket 能够实现多方之间的实时通信和数据交换,提高协作效率。

6. 游戏

  • 应用描述:多人在线游戏中的实时状态同步、玩家交互等。
  • 优势:游戏需要低延迟的实时通信来确保玩家之间的同步和交互,WebSocket 的实时性和高效性使其成为游戏开发的常用技术。

7. 实时位置追踪与导航

  • 应用描述:实时位置追踪、导航应用中的动态路线更新等。
  • 优势:通过 WebSocket,导航应用可以实时接收用户的位置信息,并根据实时交通状况动态更新路线,提高导航的准确性和实用性。

8. 直播互动

  • 应用描述:直播平台的实时评论、弹幕、礼物赠送等互动功能。
  • 优势:直播需要实时处理大量的用户互动数据,WebSocket 能够实现服务器与客户端之间的实时通信,确保观众能够实时参与直播互动。

9. 数据分析与监控

  • 应用描述:实时仪表盘、日志流处理、性能监控系统的实时数据展示与报警。
  • 优势:在数据分析和监控领域,实时性非常重要。WebSocket 能够实现数据的实时传输和展示,帮助用户及时发现问题并采取相应的措施。

七、样例

在Netty中实现WebSocket的Demo可以分为服务端和客户端两部分。以下是一个简化的Netty WebSocket Demo示例,展示了如何搭建一个基本的WebSocket服务器和客户端。

maven

确保你已经将Netty的依赖项添加到你的项目中。如果你使用Maven,可以在pom.xml文件中添加以下依赖:

<dependencies><dependency><groupId>io.netty</groupId><artifactId>netty-all</artifactId><version>4.1.x</version> <!-- 使用你需要的Netty版本 --></dependency>
</dependencies>

Netty WebSocket

WebSocket服务器的代码

import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.*;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioServerSocketChannel;
import io.netty.handler.codec.http.HttpObjectAggregator;
import io.netty.handler.codec.http.HttpServerCodec;
import io.netty.handler.codec.http.websocketx.TextWebSocketFrame;
import io.netty.handler.codec.http.websocketx.WebSocketServerProtocolHandler;
import io.netty.handler.stream.ChunkedWriteHandler;public class WebSocketServer {private int port;public WebSocketServer(int port) {this.port = port;}public void run() throws Exception {EventLoopGroup bossGroup = new NioEventLoopGroup();EventLoopGroup workerGroup = new NioEventLoopGroup();try {ServerBootstrap b = new ServerBootstrap();b.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).childHandler(new ChannelInitializer<SocketChannel>() {@Overridepublic void initChannel(SocketChannel ch) throws Exception {ChannelPipeline pipeline = ch.pipeline();// HTTP编解码器pipeline.addLast(new HttpServerCodec());// 聚合HTTP消息pipeline.addLast(new HttpObjectAggregator(65536));// 支持大消息的写操作pipeline.addLast(new ChunkedWriteHandler());// WebSocket协议处理pipeline.addLast(new WebSocketServerProtocolHandler("/ws")); // 指定WebSocket的路径为"/ws"// 自定义的WebSocket业务处理pipeline.addLast(new WebSocketServerHandler());}});// 开始监听端口ChannelFuture f = b.bind(port).sync();// 等待服务器套接字关闭f.channel().closeFuture().sync();} finally {// 关闭所有的事件循环以终止所有的线程bossGroup.shutdownGracefully();workerGroup.shutdownGracefully();}}public static void main(String[] args) throws Exception {int port;if (args.length > 0) {port = Integer.parseInt(args[0]);} else {port = 8080;}new WebSocketServer(port).run();}private static class WebSocketServerHandler extends SimpleChannelInboundHandler<TextWebSocketFrame> {@Overrideprotected void channelRead0(ChannelHandlerContext ctx, TextWebSocketFrame msg) throws Exception {// 打印接收到的消息System.out.println("Received message: " + msg.text());// 回显消息ctx.channel().writeAndFlush(new TextWebSocketFrame("Echo: " + msg.text()));}@Overridepublic void handlerAdded(ChannelHandlerContext ctx) throws Exception {// 当handler被添加到ChannelPipeline时调用System.out.println("WebSocket client connected: " + ctx.channel().remoteAddress());}@Overridepublic void handlerRemoved(ChannelHandlerContext ctx) throws Exception {// 当handler从ChannelPipeline中移除时调用System.out.println("WebSocket client disconnected: " + ctx.channel().remoteAddress());}@Overridepublic void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {// 当异常被抛出时调用cause.printStackTrace();ctx.close();}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/47438.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python的tkinter、socket库开发tcp的客户端和服务端

一、tcp通讯流程和开发步骤 1、tcp客户端和服务端通讯流程图 套接字是通讯的利器&#xff0c;连接时要经过三次握手建立连接&#xff0c;断开连接要经过四次挥手断开连接。 2、客户端开发流程 1&#xff09;创建客户端套接字 2&#xff09;和服务端器端套接字建立连接 3&#x…

Linux·基本指令(下)

1. mv 指令 (move) 语法&#xff1a;mv[选项] 源文件或目录 目标文件或目录 功能&#xff1a;将源文件或目录剪贴到一个新位置&#xff0c;或给源文件或目录改名但不会改变其内容 常用选项&#xff1a; -f &#xff1a;force 强制&#xff0c;如果目标文件已经存在&#xff0c;…

HCIE-AI大模型直通车火热报名中

第一阶段&#xff1a;HCIA-AI Solution Architect&#xff08;直播&#xff0c;39课时&#xff09; 该阶段详细介绍 AI 大模型所需基础技术栈&#xff0c;包含深度学习基础、计算机视觉技术、自然语言处理技术、华为开源深度学习框架 MindSpore、注意力制、Transformer 架构&am…

Spock单元测试框架使用介绍和实践

背景 单元测试是保证我们写的代码是我们想要的结果的最有效的办法。根据下面的数据图统计&#xff0c;单元测试从长期来看也有很大的收益。 单元测试收益: 它是最容易保证代码覆盖率达到100%的测试。可以⼤幅降低上线时的紧张指数。单元测试能更快地发现问题。单元测试的性…

CentOS Stream 卸载 Podman 并安装 Docker 的方法

目录 卸载 Podman 安装 Docker Podman 是一个无守护进程的容器引擎&#xff0c;旨在提供与 Docker 类似的命令行接口&#xff0c;但不需要守护进程运行。Podman 是 Red Hat 的开源项目&#xff0c;具有安全性、兼容性和灵活性等优点。 CentOS Stream 默认安装了 Podman 来代…

【spring boot】初学者项目快速练手

一小时带你从0到1实现一个SpringBoot项目开发_哔哩哔哩_bilibili 一、简介 二、项目结构 三、代码结构 1.生成框架 Spring Initializr 快速生成一个初始的项目代码&#xff0c;会生成一个demo文件 打开intellj idea&#xff0c;导入demo文件 2.目录结构 源码都放在src-ma…

“论软件维护方法及其应用”精选范文,软考高级论文,系统架构设计师论文

论文真题 软件维护是指在软件交付使用后&#xff0c;直至软件被淘汰的整个时间范围内&#xff0c;为了改正错误或满足 新的需求而修改软件的活动。在软件系统运行过程中&#xff0c;软件需要维护的原因是多种多样的&#xff0c; 根据维护的原因不同&#xff0c;可以将软件维护…

Lua基础知识入门

1 基础知识 标识符&#xff1a;标识符的定义和 C语言相同&#xff1a;字母和下划线_ 开头&#xff0c; 下划线_ 大写字母一般是lua保留字&#xff0c; 如_VERSION 全局变量&#xff1a;默认情况下&#xff0c;变量总是认为是全局的&#xff0c;不需要申明&#xff0c;给一个变…

window服务器thinkphp6 路由错误index.php

一&#xff0c;问题说明 访问——站点/index.php/admin/system/global————出现404错误 不想去掉index.php&#xff0c;想要保留这个————必须配置伪静态 默认的伪静态&#xff0c;是不要index.php&#xff0c;用来隐藏index.php&#xff0c;&#xff08;通过伪静态加…

电脑压缩视频文件 电脑压缩视频大小的方法

在数字化时代&#xff0c;视频已成为我们记录生活、分享快乐的重要工具。然而&#xff0c;大尺寸的视频文件常常让分享和存储变得棘手。如何在保持视频画质的前提下&#xff0c;轻松减小视频文件大小&#xff1f;今天&#xff0c;就让我们一起探索苹果电脑上的几种高效视频压缩…

Java中的方法重载详解

Java中的方法重载详解 大家好&#xff0c;我是微赚淘客系统3.0的小编&#xff0c;是个冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 1. 方法重载的定义和特点 方法重载&#xff08;Method Overloading&#xff09;指在同一个类中&#xff0c;允许有多个同名方…

HP Superdome2小型机监控指标解读

监控易是一款专注于IT基础设施监控的软件&#xff0c;能够实时监控服务器的各项性能指标&#xff0c;确保服务器的稳定运行。针对HP Superdome2小型机&#xff0c;监控易通过IPMI和网页抓取数据的方式&#xff0c;监测包括服务器温度、风扇及电压等在内的关键指标&#xff0c;为…

Postfix+Dovecot+Roundcube开源邮件系统搭建系列1-2:系统搭建目标+MariaDB数据库配置(MySQL)

1. 系统搭建目标 通过本系列文章&#xff0c;最终可以部署一套提供如下服务的邮件系统&#xff1a; SMTP服务&#xff1a;由Postfix提供&#xff0c;监听25、465、587端口。POP3服务&#xff1a;由Dovecot提供&#xff0c;监听110、995端口。IMAP服务&#xff1a;由Dovecot提…

springboot3.2 RedisCacheManager配置

1、启用并配置 添加 EnableCaching 注解 并配置 RedisCacheManager package config;import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml.jackson.annotation.JsonTypeInfo; import com.fasterxml.jackson.annotation.PropertyAccessor; import c…

Java基础笔记(面试题)

一、Tomcat中为什么要使用自定义类加载器 Tomcat中可以放多个Java项目的jar文件&#xff0c;如果每个jar文件中都有一个User的类&#xff0c;那么User类在没有自定义类加载器的情况下是只能加载一次&#xff1b;想要加载多次&#xff0c;只能自定义类加载器 二、JDK、JRE、JVM…

项目管理进阶之RACI矩阵

前言 项目管理进阶系列续新篇。 RACI&#xff1f;这个是什么矩阵&#xff0c;有什么用途&#xff1f; 在项目管理过程中&#xff0c;如Team规模超5以上时&#xff0c;则有必要采用科学的管理方式&#xff0c;满足工作需要。否则可能事倍功半。 Q&#xff1a;什么是RACI矩阵 …

【简单介绍Gitea】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

【Rust】使用日志记录利器flexi_logger

Flexi_logger简介 ​flexi_logger​是一个功能强大且灵活的日志记录库&#xff0c;用于Rust语言的应用程序。它提供了丰富的配置选项和功能&#xff0c;适用于各种日志记录需求&#xff0c;从简单的控制台输出到复杂的文件日志管理。以下是对flexi_logger​的一些关键功能和特…

观察者模式-C#

在C#中实现观察者模式&#xff0c;通常涉及两个主要的组件&#xff1a;主题&#xff08;Subject&#xff09;和观察者&#xff08;Observer&#xff09;。主题负责维护观察者列表&#xff0c;并在其状态发生变化时通知所有注册的观察者。观察者则是对主题状态感兴趣的对象&…

吴恩达大模型系列课程《Prompt Compression and Query Optimization》中文学习打开方式

Prompt Compression and Query Optimization GPT-4o详细中文注释的Colab观看视频1 浏览器下载插件2 打开官方视频 GPT-4o详细中文注释的Colab 中文注释链接&#xff1a;https://github.com/Czi24/Awesome-MLLM-LLM-Colab/tree/master/Courses/Prompt-Compression-and-Query-Op…