实战SpringCloud响应式微服务系列教程(第四章)
接上一篇:
1.1.4 引入Reactor框架
如果想在代码中集成 Reactor框架,则需要添加如下的 Maven依赖,分别引入 Reactor的核心功能以及用于支持测试的相关工具类。
<dependency>
<groupid>io.projectreactor</groupid>
<cartifactid>reactor-cores/artifactid>
</dependency>
<dependency>
<groupid>io.projectreactor</groupid>
<cartifactid>reactor-tests/artifactid>
<scope>test</scope>
</dependency>
Reactor框架在实现响应式流规范的基础上有其特定的设计思想。本节先介绍 Reactor框架的异步数据序列,然后介绍Flux和Mono这两个核心组件。
1. Reactor异步数据序列
当使用 Reactor开发响应式应用程序时,无论采用何种操作符,都将得到一个如图所示的异步数据序列。
onNext x 0..N [onError |onComplete]
以上公式包含三种不同类型方法的调用,分别处理不同场景下的消息通知。
onNext():正常的包含元素的消息通知。
onCompleted():序列结束的消息通知,可以没有。
onError():序列出错的消息通知,可以没有。
按照响应式流规范,当这些消息通知产生时,异步序列的订阅者中对应的这三个方法将被调用。如果序列没有出错,则 onerror()方法不会被调用;如果不调用 onComplete()方法,就会得到一个无限异步序列。通常,无限异步序列应该只用于测试等特殊场景。
2.Flux组件
Flux代表0至N个元素的异步序列,如下图,序列的三种消息通知都是用于Flux.
以下代码示例展示了在具体项目中使用Fux组件的方法。如果我们了解微服务架构中基于 Hystrix I的服务回退( Fallback)机制,就应该知道代码中的 getordersfallbacko是一个典型的回退函数,我们通过FIux.fromlterableo方法构建了 Flux<Order>
对象,作为回退函数的返回值。
关于服务回退机制,将在之后章节中具体介绍
private Flux<order> getordersfallback(){
List<order> fallbacklist = new Arraylist<>();
Order order= new Order();
order.setid("orderinvalidid");
order.setaccountid("Invalidid");
order.setitem("Order list is not available");
order.setcreatetime (new Date();
fallbacklist.add (order);
return Flux.fromiterable (fallbacklist);
}
下面的示例更加容易理解一点,从位于方法名上的@ Getmapping注解可以看出,这是个 Controller中的端点,用于返回一个 Order对象列表。这里返回的 Order列表同样通过Flux< Order>
对象进行呈现。
@getmapping("/vl/orders")
public Flux<Order> getorderlist(){
Flux<order> orders= orderservice. getorders();
return orders;
}
3.Mono组件
在 Reactor中,Mono表示包含0个或1个元素的异步序列,如图所示,该序列中同样可以包含与Fux相同的三种类型的消息通知。
请注意,Mono也可以用来表示一个空的异步序列,该序列没有任何元素,仅仅包含序列结束的概念(类似于Java中的 Runnable)。我们可以用Mono<void>
代表一个空的异步序列。
与FIux组件一样,通过服务回退来演示Mono组件的用法,示例代码如下。
private Mono<order> getorderfallback(){
Order order = new Order();
order.setid("orderinvalidid");
order.setaccountid("Invalidid");
order.setitem("Order list is not available");
order.setcreatetime(new Date());
return Mono.just(order);
}
这里首构建一个 Order对象,然后通过 Mono.just()方法返回一个Mono对象。
Controller层组件也是一样的,通过d获取Mono<Order>
对象的端点示例如下。
@tapping("/vl/orders/{id}")
public Mono<order> getorder(@Pathvariable String id){
Mono<order> order orderservice.getorderbyid(id);
return order;
}
相较Mono,Flux是更通用的一种响应式组件,所以针对FIux的操作要比Mono更丰富。另一方面,FIux和Mono之间可以相互转换。例如,把两个Mono序列合并起来就得到一个Flux序列,而对一个FIux序列进行计数操作,得到的就是Mono对象。
实战SpringCloud响应式微服务系列教程(第四章)的更多相关文章
- 实战SpringCloud响应式微服务系列教程(第二章)
接上一篇:实战SpringCloud响应式微服务系列教程(第一章) 1.1.2背压 背压是响应式编程的核心概念,这一节也是我们了解响应式编程的重点. 1.背压的机制 在生产者/消费者模型中,我们意识到 ...
- 实战SpringCloud响应式微服务系列教程(第九章)使用Spring WebFlux构建响应式RESTful服务
本文为实战SpringCloud响应式微服务系列教程第九章,讲解使用Spring WebFlux构建响应式RESTful服务.建议没有之前基础的童鞋,先看之前的章节,章节目录放在文末. 从本节开始我们 ...
- 实战SpringCloud响应式微服务系列教程(第一章)
前言 在当今互联网飞速发展的时代,业务需求不断的更新和产品的迭代给系统开发过程和编程模式也带来巨大挑战,Spring Cloud微服务也随之应用而生,从springboot1.x到springboot ...
- 实战SpringCloud响应式微服务系列教程(第三章)
接着之前的: 实战SpringCloud响应式微服务系列教程(第一章) 实战SpringCloud响应式微服务系列教程(第二章) 1.1.3Reactor框架 响应式编程是一种编程模型,本节将介绍这种 ...
- 实战SpringCloud响应式微服务系列教程(第六章)
本章节介绍:Flux和Mono操作符 和其他主流的响应式编程一样,Reactor框架的设计目标也是为了简化相应式流的使用方法.为此Reactor框架提供了大量操作符用于操作Flux和Mono对象. 本 ...
- 实战SpringCloud响应式微服务系列教程(第七章)
本章节继续介绍:Flux和Mono操作符(二) 1.条件操作符 Reactor中常用的条件操作符有defaultIfRmpty.skipUntil.skipWhile.takeUntil和takeWh ...
- 实战SpringCloud响应式微服务系列教程(第八章)构建响应式RESTful服务
本文为实战SpringCloud响应式微服务系列教程第八章,讲解构建响应式RESTful服务.建议没有之前基础的童鞋,先看之前的章节,章节目录放在文末. 1.使用springboot2.1.4构建RE ...
- 实战SpringCloud响应式微服务系列教程(第十章)响应式RESTful服务完整代码示例
本文为实战SpringCloud响应式微服务系列教程第十章,本章给出响应式RESTful服务完整代码示例.建议没有之前基础的童鞋,先看之前的章节,章节目录放在文末. 1.搭建响应式RESTful服务. ...
- Cobalt Strike系列教程第四章:文件/进程管理与键盘记录
Cobalt Strike系列教程分享如约而至,新关注的小伙伴可以先回顾一下前面的内容: Cobalt Strike系列教程第一章:简介与安装 Cobalt Strike系列教程第二章:Beacon详 ...
随机推荐
- C#3.0新增功能09 LINQ 基础07 LINQ 中的查询语法和方法语法
连载目录 [已更新最新开发文章,点击查看详细] 介绍性的语言集成查询 (LINQ) 文档中的大多数查询是使用 LINQ 声明性查询语法编写的.但是在编译代码时,查询语法必须转换为针对 .NET ...
- Git 安装及使用指南
1 简介1.1 Git1.2 Github2 Git 在 Windows 下的安装和使用2.1 msysgit2.2 Tortoisegit2.2.1 安装2.2.2 配置2.2.3 简单使用 1 简 ...
- 一文带你实现RPC框架
想要获取更多文章可以访问我的博客 - 代码无止境. 现在大部分的互联网公司都会采用微服务架构,但具体实现微服务架构的方式有所不同,主流上分为两种,一种是基于Http协议的远程调用,另外一种是基于RPC ...
- java高并发系列 - 第17天:JUC中的循环栅栏CyclicBarrier常见的6种使用场景及代码示例
这是java高并发系列第17篇. 本文主要内容: 介绍CyclicBarrier 6个示例介绍CyclicBarrier的使用 对比CyclicBarrier和CountDownLatch Cycli ...
- lnmp php使用命令行去备份数据库
<?php //备份数据库we8和foshan $time = date("Y-m-d",time()); $backtime = date("Y-m-d" ...
- linuk下proftpd安装
Linux下Proftpd安装与配置 1.下载 下载地址:ftp://ftp.proftpd.org/distrib/source/proftpd-1.3.6rc1.tar.gz 文件下载到/soft ...
- 【iOS】The identity used sign the executable is no longer valid.
之前就遇到过这个问题,如图: 今天又遇到了,证书过期的问题. 需要访问苹果开发者的官网 http://developer.apple.com 来解决. 参考:How to fix “The ident ...
- spring注解不支持静态变量注入
spring注解不支持静态变量注入:今天敲代码 自动配置 配置: Animal.java package study01_autoconfig.beanConfig; import org.spri ...
- 从js 讲解时间复杂度和空间复杂度
1. 博客背景 今天有同事在检查代码的时候,由于函数写的性能不是很好,被打回去重构了,细思极恐,今天和大家分享一篇用js讲解的时间复杂度和空间复杂度的博客 2. 复杂度的表示方式 之前有看过的,你可能 ...
- python3 编译安装
前言: Linux下大部分系统默认自带python2.x的版本,最常见的是python2.6或python2.7版本,默认的python被系统很多程序所依赖,比如centos下的yum就是python ...