重学SpringBoot3-Spring WebFlux简介
更多SpringBoot3内容请关注我的专栏:《SpringBoot3》
期待您的点赞👍收藏⭐评论✍
重学SpringBoot3-Spring WebFlux简介
- 1. 什么是 WebFlux?
- 2. WebFlux 与 Spring MVC 的区别
- 3. WebFlux 的用处
- 3.1 非阻塞 I/O 操作
- 3.2 响应式编程模型
- 3.3 更高的性能和可扩展性
- 3.4 支持多种 Web 容器
- 4. WebFlux 的应用场景
- 4.1 高并发 Web 应用
- 4.2 微服务架构中的异步服务
- 4.3 实时数据流应用
- 5. 如何在 Spring Boot 3 中使用 WebFlux
- 6. 总结
随着微服务架构的流行和对高并发、低延迟系统需求的增加,响应式编程逐渐成为现代应用开发的主流方式之一。Spring Boot 3 引入了对响应式编程的强大支持,其中 Spring WebFlux 是一个重要的模块。本文将介绍 Spring WebFlux 的概念、特点以及它在实际应用中的场景和优势。
1. 什么是 WebFlux?
Spring WebFlux 是 Spring Framework 5 中引入的一个响应式 Web 框架,它是为了支持非阻塞异步通信和响应式流处理而设计的。与传统的基于 Servlet 的 Spring MVC 模型不同,WebFlux 基于Reactive Streams 规范,提供了一种完全异步和非阻塞的编程模型。
WebFlux 核心基于 Reactor 项目,使用 Mono
和 Flux
这两个主要的反应式抽象来处理单值和多值的流。
2. WebFlux 与 Spring MVC 的区别
Spring MVC 是基于 Servlet 规范的,它使用同步阻塞式的 I/O 模型,适合传统的 Web 应用程序。每个请求对应一个线程,在处理请求的过程中,线程可能会因为 I/O 操作(例如数据库查询或远程调用)而处于阻塞状态。
而 WebFlux 则是完全异步的,它使用了 Netty 或 Undertow 这样的非阻塞服务器。WebFlux 应用的每个请求并不占用线程去等待 I/O 结果,而是基于事件驱动模型,当有数据准备好时才进行处理,这极大地提高了并发处理的能力和资源利用率。
API功能 | Servlet-阻塞式Web | WebFlux-响应式Web |
---|---|---|
前端控制器 | DispatcherServlet | DispatcherHandler |
处理器 | Controller | WebHandler/Controller |
请求、响应 | ServletRequest、ServletResponse | ServerWebExchange:ServerHttpRequest、ServerHttpResponse |
过滤器 | Filter(HttpFilter) | WebFilter |
异常处理器 | HandlerExceptionResolver | DispatchExceptionHandler |
Web配置 | @EnableWebMvc | @EnableWebFlux |
自定义配置 | WebMvcConfigurer | WebFluxConfigurer |
返回结果 | 任意 | Mono、Flux、任意 |
发送REST请求 | RestTemplate | WebClient |
3. WebFlux 的用处
3.1 非阻塞 I/O 操作
WebFlux 最显著的特点是其非阻塞 I/O 操作。在处理高并发场景时,WebFlux 能够避免因大量线程阻塞等待 I/O 而带来的性能开销。非阻塞模型可以使应用在处理大量请求时具备更高的可伸缩性。
例如,在微服务架构中,服务之间经常需要通过 RESTful API 进行通信。使用 WebFlux 可以构建高效的非阻塞服务,这些服务可以同时处理大量请求,而不会因为等待外部系统的响应而消耗大量资源。
3.2 响应式编程模型
WebFlux 基于响应式编程,提供了一个更适合流式数据处理的编程范式。它使用 Flux
和 Mono
作为核心抽象:
- Mono:表示 0 或 1 个元素的异步序列。
- Flux:表示 0 到 N 个元素的异步序列。
通过这些抽象,开发者可以方便地处理数据流、组合异步操作,并且能够轻松处理如 backpressure(背压)等复杂的场景。
3.3 更高的性能和可扩展性
由于 WebFlux 是异步非阻塞的,它能够更有效地利用 CPU 和内存资源,特别是在处理高并发请求时。与传统的同步阻塞模型相比,WebFlux 应用通常能更好地处理大量并发请求,而不会遇到线程耗尽的问题。
3.4 支持多种 Web 容器
WebFlux 不是基于传统的 Servlet 容器,而是支持 Netty 和 Undertow 等非阻塞服务器。此外,它也可以运行在支持 Servlet 3.1+ 规范的容器(如 Tomcat 和 Jetty)中,但在这种情况下,WebFlux 会以异步非阻塞的方式运行。
4. WebFlux 的应用场景
WebFlux 非常适合以下场景:
4.1 高并发 Web 应用
对于需要处理大量并发请求的 Web 应用,WebFlux 提供了良好的解决方案。它的非阻塞特性允许应用更好地扩展,并在高负载下表现出色。
4.2 微服务架构中的异步服务
在微服务架构中,各个服务之间经常需要进行远程调用,这些调用可能涉及 I/O 操作,例如与数据库的交互或调用其他服务的 API。WebFlux 允许你以响应式的方式实现这些异步操作,从而提高服务之间通信的效率。
4.3 实时数据流应用
如果你的应用需要处理实时数据流(如消息处理、WebSocket 通信等),WebFlux 的响应式编程模型可以让你轻松构建复杂的流式数据处理逻辑,并且具备良好的性能和可维护性。
5. 如何在 Spring Boot 3 中使用 WebFlux
在 Spring Boot 3 中启用 WebFlux 非常简单。你只需要添加相关依赖即可:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId></dependency>
接着,你可以定义控制器和服务层来使用 Mono
和 Flux
处理请求。以下是一个简单的 WebFlux 控制器示例:
package com.coderjia.boot3webflux.controller;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;/*** @author CoderJia* @create 2024/10/19 下午 08:05* @Description**/
@RestController
@RequestMapping("/api")
public class WebFluxController {@GetMapping("/mono")public Mono<String> getMono() {return Mono.just("Hello, Mono!");}@GetMapping("/flux")public Flux<String> getFlux() {return Flux.just("Hello", "World", "From", "WebFlux", "Controller", "in", "Spring Boot 3!");}
}
在这个示例中,/mono
返回一个 Mono
对象,表示异步地返回一个字符串,
而 /flux
返回一个 Flux
对象,表示一系列的字符串数据流。通过这种方式,你可以使用 WebFlux 构建异步非阻塞的 Web API。
6. 总结
Spring WebFlux 是一种基于响应式编程的非阻塞 Web 框架,它为构建高性能、高并发的现代 Web 应用提供了强大的支持。通过使用 WebFlux,开发者可以充分利用异步 I/O 和响应式流处理的优势,构建具有良好可扩展性和性能表现的应用。
WebFlux 在高并发、微服务架构和流式数据处理等场景中表现出色。如果你的应用需要处理大量并发请求或实时数据流,WebFlux 是一个值得考虑的技术选择。后面文章会继续介绍 WebFlux 相关应用。
相关文章:

重学SpringBoot3-Spring WebFlux简介
更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-Spring WebFlux简介 1. 什么是 WebFlux?2. WebFlux 与 Spring MVC 的区别3. WebFlux 的用处3.1 非阻塞 I/O 操作3.2 响应式编程模型3.3 更高…...

distinct 和 group by
最近生产加了一个新字段 a、然后将主键赋值给 a 然后投产后验证是否有漏网之鱼。当时使用的是 select count(distinct pk),count(distinct a) from tableName当时在想这样子跟 group by 有啥区别 select a from tableName group by a having count(a) > 1所以查一下两者…...

RTThread-Nano学习一-基于MDK移植
一、简介 关于RTThread-nano的介绍,这里不做过多解释,官方文档已经介绍的非常详细了,有兴趣的可以参考如下文档:RT-Thread 文档中心 二、移植 1.准备一个能正常运行的代码 手头有M0内核的板子,那就以…...
Vue中v-bind对样式控制的增强—(详解v-bind操作class以及操作style属性,附有案例+代码)
文章目录 v-bind对样式控制的增强2.1 操作class2.1.1 语法2.1.2 对象语法2.1.3 数组语法2.1.4 使用2.1.5 Test 2.2 操作style2.2.1 语法2.2.2 使用2.2.3 Test v-bind对样式控制的增强 2.1 操作class 2.1.1 语法 <div> :class "对象/数组">这是一个div&l…...
【分布式微服务云原生】《ZooKeeper 深度探秘:分布式协调的强大利器》
**《ZooKeeper 深度探秘:分布式协调的强大利器》 ** 摘要:本文将深入详解 ZooKeeper,涵盖其工作原理、实现分布式锁的方法、应用场景、负载均衡的实现以及不同角色的作用等内容。读者将全面了解 ZooKeeper 的强大功能和价值,为构…...

打造高性能在线电子表格:WebGL 渲染引擎 Kola2d 自研之路
导读:本文主要阐述了 Docs 在线表格为打造极致渲染性能所做的关键优化和过程思考,作为首个在在线电子表格领域自研基于WebGL渲染引擎的「吃螃蟹」者,整个过程面临诸多不确定性与挑战,Kola2d 的整体设计在此期间也经历了几轮推倒重…...

深入理解WPF中的命令机制
Windows Presentation Foundation(WPF)是微软推出的一种用于构建桌面客户端应用程序的技术。它被认为是现代Windows应用程序的基础,具有强大的图形和媒体处理能力。在WPF中,“命令”是一个重要的概念,它为应用程序开发…...

基础算法(6)——模拟
1. 替换所有的问号 题目描述: 算法思路: 从前往后遍历整个字符串,找到问号之后,尝试用 a ~ z 的每一个字符替换即可 注意点:需考虑数组开头和结尾是问号的边界情况 代码实现: class Solution {public …...

2025年广西高考报名流程图解(手机端)
广西 2025 年高考报名时间已经确定啦,从 2024 年 10 月 21 日开始,到 10 月 31 日 17:30 结束 💻【报名路径】 有电脑端和手机端两种选择哦。 电脑端:登录 “广西招生考试院” 网站(https://www.gxeea.cn࿰…...
十、结构型(外观模式)
外观模式(Facade Pattern) 概念 外观模式(Facade Pattern)是一种结构型设计模式,旨在为复杂子系统提供一个简化的统一接口。通过外观模式,客户端可以与子系统交互,而无需了解子系统的内部复杂性…...
10.12Python数学基础-矩阵(上)
矩阵 1.矩阵定义 1.1 矩阵的定义 矩阵是由一组数按照矩形排列而成的数表。矩阵通常用大写字母表示,例如 AA、BB 等。矩阵中的每个数称为矩阵的元素或元。 一个 mn的矩阵 AA 可以表示为: A ( a 1 n a 12 … a 1 n a 21 a 22 … a 2 n ⋮ a m 1 a m 2…...

重学SpringBoot3-安装Spring Boot CLI
更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-安装Spring Boot CLI 1. 什么是 Spring Boot CLI?2. Spring Boot CLI 的安装2.1. 通过 SDKMAN! 安装2.2. 通过 Homebrew 安装(适…...

代码复现(五):GCPANet
文章目录 net.py1.class Bottleneck:残差块2.class ResNet:特征提取3.class SRM:SR模块4.class FAM:FIA模块5.class CA:GCF模块6.class SA:HA模块7.class GCPANet:网络架构 train.pytest.py 论文…...

联邦学习实验复现—MNISIT IID实验 pytorch
联邦学习论文复现🚀 在精度的联邦学习的论文之后打算进一步开展写一个联邦学习的基础代码,用于开展之后的相关研究,首先就是复现一下论文中最基础也是最经典的MNIST IID(独立同分布划分) 数据集。然后由于这个联邦学习的论文是谷歌发的&#…...

2015年-2017年 计算机技术专业 程序设计题(算法题)实战_c语言程序设计数据结构程序设计分析
文章目录 20151.C语言算法设计部分2.数据结构算法设计部分 20161.C语言算法设计部分2.数据结构算法设计部分 2017年1. C语言算法设计部分2.数据结构算法设计部分 2015 1.C语言算法设计部分 int total(int n) {if(n1) return 1;return total(n-1)n1; } //主函数测试代码已省略…...

个人用计算理论导引笔记(待补充)
文章目录 一、正则语言预备知识确定性有穷自动机(DFA)设计DFA正则运算 非确定性有穷自动机(NFA,含有 ε \varepsilon ε,下一个状态可以有若干种选择(包括0种))正则表达式定义计算优…...

2024年诺贝尔物理学奖揭晓:AI背后的“造梦者”是谁?
想象一下,你早上醒来,智能音箱为你播放天气和新闻,中午你用手机刷视频,精准的推荐内容简直和你心有灵犀,晚上回家,自动驾驶汽车安全地把你送回家。这一切看似理所当然,背后却有一双无形的手推动…...

2024年AI 制作PPT新宠儿,3款神器集锦,让你的演示与众不同
咱们今儿聊聊最近超火的AI做PPT的工具。这年头,谁不想省事儿,少熬夜加班,多享受享受生活啊?所以,AI开始帮咱们搞定做PPT这种费时的活儿,我自然得好好研究研究。今天,我就给大家详细说说三款很火…...

CLion和Qt 联合开发环境配置教程(Windows和Linux版)
需要安装的工具CLion 和Qt CLion下载链接 :https://www.jetbrains.com.cn/clion/ 这个软件属于直接默认安装就行,很简单,不多做介绍了 Qt:https://mirrors.tuna.tsinghua.edu.cn/qt/official_releases/online_installers/ window 直接点exe Linux 先c…...
Qt记录使用QtAwesome
Qt记录使用QtAwesome 基本使用 基本使用 pro文件添加 CONFIG fontAwesomeFree include(QtAwesome/QtAwesome.pri) //实例化QtAwesome fa::QtAwesome* awesome new fa::QtAwesome(this); awesome->initFontAwesome();//设置外置适应 图标ICON的颜色color QVariantMap opt…...

7.4.分块查找
一.分块查找的算法思想: 1.实例: 以上述图片的顺序表为例, 该顺序表的数据元素从整体来看是乱序的,但如果把这些数据元素分成一块一块的小区间, 第一个区间[0,1]索引上的数据元素都是小于等于10的, 第二…...

简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止
<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet: https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...

STM32F4基本定时器使用和原理详解
STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...
浅谈不同二分算法的查找情况
二分算法原理比较简单,但是实际的算法模板却有很多,这一切都源于二分查找问题中的复杂情况和二分算法的边界处理,以下是博主对一些二分算法查找的情况分析。 需要说明的是,以下二分算法都是基于有序序列为升序有序的情况…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...

均衡后的SNRSINR
本文主要摘自参考文献中的前两篇,相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程,其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt 根发送天线, n r n_r nr 根接收天线的 MIMO 系…...

JVM虚拟机:内存结构、垃圾回收、性能优化
1、JVM虚拟机的简介 Java 虚拟机(Java Virtual Machine 简称:JVM)是运行所有 Java 程序的抽象计算机,是 Java 语言的运行环境,实现了 Java 程序的跨平台特性。JVM 屏蔽了与具体操作系统平台相关的信息,使得 Java 程序只需生成在 JVM 上运行的目标代码(字节码),就可以…...
QT3D学习笔记——圆台、圆锥
类名作用Qt3DWindow3D渲染窗口容器QEntity场景中的实体(对象或容器)QCamera控制观察视角QPointLight点光源QConeMesh圆锥几何网格QTransform控制实体的位置/旋转/缩放QPhongMaterialPhong光照材质(定义颜色、反光等)QFirstPersonC…...

群晖NAS如何在虚拟机创建飞牛NAS
套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享...