当前位置: 首页 > ds >正文

Spring WebFlux和Spring MVC的对比

原文网址:Spring WebFlux和Spring MVC的对比-CSDN博客

简介

本文介绍Spring WebFlux和Spring MVC的区别。

Webflux:是异步非阻塞的(IO多路复用),基于Netty。适合网络转发类的应用,比如:网关。
MVC:是同步阻塞的,基于Servlet。适合阻塞性的业务应用,比如:读写数据库等普通业务。

Webflux和MVC

功能性

Overview :: Spring Framework

Spring MVC 和 WebFlux 可以共存

在一个同时引入了 Spring MVC 和 Spring WebFlux 的项目中,Spring 通过请求路径的映射机制以及底层的配置来区分应该将请求交给谁处理(DispatcherServlet 或 WebHandler)。

返回值类型决定了处理器:

  • 如果控制器方法返回阻塞类型(如 String、ResponseEntity<T>),请求会由 Spring MVC 的 DispatcherServlet 处理。
  • 如果控制器方法返回响应式类型(如 Mono<T> 或 Flux<T>),请求会由 Spring WebFlux 的 WebHandler 处理。

Spring 的默认行为限制:

  • Spring MVC 控制器和Spring WebFlux 控制器在逻辑上是完全独立的。
  • 同一个控制器(@RestController 类)不能混用阻塞式方法和响应式方法。否则,Spring 不知道该为这个控制器注册到哪个处理器中(因为一个控制器只能归属到一个处理器)。
     

官方使用建议

官方建议:

  1. 如果已经有了一个运行良好的SpringMVC 应用程序,则无需更改。命令式编程是编写、理解和调试代码的最简单方法,我们可以选择最多的库,因为从历史上看,大多数都是阻塞的。
  2. 如果是个新应用且决定使用 非阻塞 Web 技术栈,那么 WebFlux 是个不错的选择。
  3. 对于使用 Java8 Lambda 或者 Kotlin 且 要求不那么复杂的小型应用程序或微服务来说,WebFlux 也是一个不错的选择。
  4. 在微服务架构中,可以混合使用 SpringMVC 和 Spring WebFlux,两个都支持基于注解的编程模型。
  5. 评估应用程序的一种简单方法是检查其依赖关系。如果要使用阻塞持久性 API(JPA、JDBC)或网络 API,那么 Spring MVC 至少是常见架构的最佳选择。
  6. 如果有一个调用远程服务的 Spring MVC 应用程序,请尝试响应式WebClient。
  7. 对于一个大型团队,向非阻塞、函数式和声明式编程转变的学习曲线是陡峭的。在没有全局开关的情况下,想启动 WebFlux,可以先使用 reactive WebClient。

Reactive和Servlet

官网地址:https://spring.io/reactive

总结

Spring Webflux的特点:

  1. 不能使接口的响应时间缩短,它仅仅能够提升吞吐量和伸缩性。
  2. 内部是响应式编程,以Reactor库为基础,基于异步和事件驱动,适合应用在网络IO密集型的服务中,如网关。
  3. 不是Spring MVC的替代方案,它们是不同的应用场景。
  4. 默认情况下使用Netty作为服务器,不支持MySQL。
  5. 前端控制器是DispatcherHandler(Spring MVC是DispatcherServlet。)
  6. 支持两种编程风格,一种是Spring MVC的注解形式,另一种是Java 8 Lambda函数式编程。
  7. 类型:Mono返回0或者1个元素,即单个对象。Flux返回N个元素,即List列表对象。
  8. 没有拦截器概念,类似的工作需要在过滤器中完成,例如:Token验证用过滤器。
  9. 可以用@ControllerAdvice注册全局异常处理器,但它仅对Controller中抛出的异常生效,无法顾及到过滤器。对异常,推荐的方式是注册WebExceptionHandler。 
http://www.xdnf.cn/news/14729.html

相关文章:

  • AR 眼镜之-条形码识别-实现方案
  • Lua 事务双写、RedisGears 异步双写、零停机索引迁移与容量预估
  • PLuTo 编译器示例17-20
  • Unix、Linux、POSIX、Minix 区别与联系
  • 大内存对电脑性能有哪些提升
  • 云计算处理器选哪款?性能与能效的平衡艺术
  • Transformer实战——Hugging Face环境配置与应用详解
  • 深入理解JVM执行引擎
  • C++ inline变量
  • 开源ChatBI :深入解密 Spring AI Alibaba 的中文NL2SQL智能引擎
  • css语法中的选择器与属性详解:嵌套声明、集体声明、全局声明、混合选择器
  • 算法打卡22天
  • 如何在 MX Linux 上安装 Remmina
  • 简单理解HTTP/HTTPS协议
  • PGCE 认证-PostgreSQL 中级专家企业级能力背书,培训直通技术核心
  • 详解鸿蒙Next仓颉开发语言中的全屏模式
  • 从Excel到知识图谱再到数据分析:数据驱动智能体构建指南
  • 短视频批量混剪怎么做?
  • 关系数据库中的事务——SqlServer为例说明
  • 【强化学习】PPO(Proximal Policy Optimization,近端策略优化)算法
  • 今天我想清楚了
  • Vue添加图片作为水印
  • Vue.js 按键修饰符详解:提升键盘事件处理效率
  • AndroidView的简单使用
  • 【AI Study】第四天,Pandas(6)- 性能优化
  • 配置外设参数与时钟频率 (PCLK1, PCLK2) 的关系
  • vue3 javascript 复杂数值计算操作技巧
  • 一个简单的图书馆管理系统
  • web和uniapp接入腾讯云直播
  • 意法STM32F103C8T6 单片机ARM Cortex-M3 国民MCU 电机控制到物联网专用