目录
webmvc和webflux作为spring framework的两个重要模块,代表了两个io模型,阻塞式和非阻塞式。
1、webmvc
webmvc是基于servlet的阻塞式模型,一个请求到达服务器后会单独分配一个线程去处理请求,如果请求包含io操作,线程在io操作结束之前一直处于阻塞等待状态,这样线程在等待io操作结束的时间就浪费了。
2、webflux
webflux是一个异步非阻塞式的 web 框架,它能够充分利用多核 cpu 的硬件资源去处理大量的并发请求。
webflux内部使用的是响应式编程(reactive programming),以 reactor 库为基础,基于异步和事件驱动,可以让我们在不扩充硬件资源的前提下,提升系统的吞吐量和伸缩性。
reactor 是一个反应式库,用于根据反应式流规范在 jvm 上构建非阻塞应用。它是完全非阻塞的,支持在 netty,undertow 和 servlet 3.1 容器等服务器上运行。
reactor 项目提供两种类型的发布者:
- flux 是产生 0 到 n 个值的发布者,返回多个元素的操作使用此类型;
- mono 是产生 0 到 1 值的发布者,它用于返回单个元素的操作;
3、webflux实例
添加依赖
org.springframework.boot spring-boot-starter-webflux
添加controller
@slf4j @restcontroller @requestmapping("/api/user") public class userreactivecontroller { @requestmapping(value = "/hello") public mono