响应式编程(一)什么是响应式编程 |
您所在的位置:网站首页 › 什么是声明式编程 › 响应式编程(一)什么是响应式编程 |
响应式编程是相对于阻塞式编程,我们在这里主要讲的是springBoot2中响应式webflux Spring Boot 2.0 WebFlux了解 WebFlux,首先了解下什么是 Reactive Streams。Reactive Streams 是 JVM 中面向流的库标准和规范: 处理可能无限数量的元素 按顺序处理 组件之间异步传递 强制性非阻塞背压(Backpressure) Backpressure(背压)背压是一种常用策略,使得发布者拥有无限制的缓冲区存储元素,用于确保发布者发布元素太快时,不会去压制订阅者。 Reactive Streams(响应式流)一般由以下组成: 发布者:发布元素到订阅者 订阅者:消费元素 订阅:在发布者中,订阅被创建时,将与订阅者共享 处理器:发布者与订阅者之间处理数据 响应式编程有了 Reactive Streams 这种标准和规范,利用规范可以进行响应式编程。那再了解下什么是 Reactive programming 响应式编程。响应式编程是基于异步和事件驱动的非阻塞程序,只是垂直通过在 JVM 内启动少量线程扩展,而不是水平通过集群扩展。这就是一个编程范例,具体项目中如何体现呢? 响应式项目编程实战中,通过基于 Reactive Streams 规范实现的框架 Reactor 去实战。Reactor 一般提供两种响应式 API : Mono:实现发布者,并返回 0 或 1 个元素 Flux:实现发布者,并返回 N 个元素 Spring Webflux Spring Boot Webflux 就是基于 Reactor 实现的。Spring Boot 2.0 包括一个新的 spring-webflux 模块。该模块包含对响应式 HTTP 和 WebSocket 客户端的支持,以及对 REST,HTML 和 WebSocket 交互等程序的支持。一般来说,Spring MVC 用于同步处理,Spring Webflux 用于异步处理。 Spring Boot Webflux 有两种编程模型实现,一种类似 Spring MVC 注解方式,另一种是使用其功能性端点方式。注解的会在第二篇文章讲到,下面快速入门用 Spring Webflux 功能性方式实现。 Spring Boot 2.0 WebFlux 特性常用的 Spring Boot 2.0 WebFlux 生产的特性如下: 响应式 API 编程模型 适用性 内嵌容器 Starter 组件 还有对日志、Web、消息、测试及扩展等支持。 响应式 APIReactor 框架是 Spring Boot Webflux 响应库依赖,通过 Reactive Streams 并与其他响应库交互。提供了 两种响应式 API:Mono 和 Flux。一般是将 Publisher 作为输入,在框架内部转换成 Reactor 类型并处理逻辑,然后返回 Flux 或 Mono 作为输出。 Spring Boot 2.0 WebFlux 组件 Spring Boot WebFlux 官方提供了很多 Starter 组件,每个模块会有多种技术实现选型支持,来实现各种复杂的业务需求: Web:Spring WebFlux 模板引擎:Thymeleaf 存储:Redis、MongoDB、Cassandra,不支持 MySQL 内嵌容器:Tomcat、Jetty、Undertow
|
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |