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

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。 

相关文章:

  • 字符编码(UTF-8,16,32 和GBK和ASCLL码)
  • conda(Anaconda/Miniconda)常用命令
  • 使用 `Expect` 工具实现了自动化文件传输
  • c++11右值引用(rvalue reference)
  • FastAPI lifespan示例
  • 生态环评GIS/遥感制图:土地利用+植被覆盖+土壤侵蚀+水系提取,ArcGIS+ENVI实战
  • 响应式数据可视化大屏解决方案,重构工业交互体验
  • Chapter15 cross-origin resource sharing
  • Windsurf SWE-1模型评析:软件工程的AI革命
  • 上海人工智能实验室明珠湖会议首开,解答AI前沿疑问,推进科学智能
  • [论文阅读] 人工智能+软件工程 | 用大语言模型架起软件需求形式化的桥梁
  • 组态王工程运行时间显示
  • 开疆智能ModbusTCP转EtherCAT网关连接IVO编码器配置案例
  • 华为云Flexus+DeepSeek征文 | 利用Dify平台构建多智能体协作系统:从单体到集群的完整方案
  • 可编辑64页PPT | 基于DeepSeek的数据治理方案
  • CARSIM-与C#自动化测试方案
  • 自托管媒体跟踪器Yamtrack
  • MySQL 数据库索引详解
  • 微软数据分析师PL-300证书怎么考?
  • Python图像处理与计算机视觉:OpenCV实战指南
  • 济宁网站建设多少钱/如何写市场调研报告
  • wordpress登录链接/湖南seo排名
  • wordpress 导航站主题/班级优化大师官网登录
  • 西宁网站制作费用是多少/做seo网页价格
  • 企业做网站用dedeCMS免费吗/google官网登录
  • 简单的公司网站系统/制作网页完整步骤