实战SpringCloud响应式微服务系列教程(第一章)

作者:瑾年 微信公众号: Java知音

前言

在当今互联网飞速发展的时代,业务需求不断的更新和产品的迭代给系统开发过程和编程模式也带来巨大挑战,Spring Cloud微服务也随之应用而生,从springboot1.x到springboot2.x,springcloud也提供了相应的集成,而特别引人注目的是spring5的诞生确实为java编程模式带来重大革命。

Spring5框架集成的project Reactor响应式开发框架为构建响应式RESTful服务、响应式数据访问组件、响应式消息通信组件、响应式微服务带来更好的便利之处。

接下来的文章会从“响应式编程模型和Reactor框架”,“构建响应式RESTful服务”,“构建响应式数据访问组件”、“响应式消息通信组件”、“响应式微服务”等方面全面了解掌握如何利用Reactor框架中的Mono和Flux两个核心组件,如何利用Spring5中的Spring WebFlux支持使用注解式编程模型和函数式编程模型构建响应式RESTful服务。

同时也会全面讲解springboot中WebFlux,如何利用Spring Data提供的 spring Reactive Data 构建响应式数据访问组件,如何使用Reactiv Spring Cloud Stream实现响应式消息通信组件。

通过使用 Spring Cloud框架实现响应式微服务,我们将会从服务发现、服务治理、负载均衡、服务容错、服务网关、服务监控等方面全面了解响应式微服务的核心组件及其实现方案。

在我们全面了解和掌握构建响应式微服务后将会有实际的项目源码供大家学习交流。

作者的水平和经验也有限,文章中难免会有纰漏之处和错误之处,恳请各位看官理解、批评和指正。

image

响应式编程模型和Reactor框架

响应式编程模型(简称RP Reactive Programming)是一种全新的编程模型,包含流、背压等核心概念。

百度百科解释:响应式编程是一种面向数据流和变化传播的编程范式。这意味着可以在编程语言中很方便地表达静态或动态的数据流,而相关的计算模型会自动将变化的值通过数据流进行传播。

Reactor 框架是 Pivotal 公司(开发 Spring 等技术的公司)开发的,实现了 Reactive Programming 思想,符合 Reactive Streams 规范(Reactive Streams 是由 Netflix、TypeSafe、Pivotal 等公司发起的)的一项技术。其名字有反应堆之意,反映了其背后的强大的性能。

1.1响应式编程模型

首先从传统编程模型到响应式编程模型我们需要一个转变。我们将从简单的接口定义实力开始,引出响应式编程中的一系列核心概念。

例如我们定义一个属于数据访问层的接口访问use对象数据列表:

public interface userMapper{
  List<User> getUsers();
}

从上面的接口我们可以看出User对象可能是一个也可能是成千上万个,在真实数据返回之前,我们无法知道具体的对象个数,显然在日常开发中我们认为这种方式定义是有问题的,如果返回的数据量过大,则可能会导致内存溢出等问题,所以我们在日常开发中对返回的数据做了一下调整:

public interface userMapper{
  Page<User> getUsers(Page page);
}

可以看到我们传入了办函分页的Page对象,返回一个分页结果对象。

在这个分页机制当中,我们一般需要传入每一页的大小参数,也就是我们所理解的pageSize,以及我们想要获取的页码参数(pageNum)。也就是说每次请求返回对象的个数是固定的。

那么我们在响应式编程中该如何处理这种数据返回呢?

在响应式编程模型中,这件事情就会变的简单很多。我们将会返回一个容器,让客户端自己去选择需要的对象个数,客户端想要多少该容器就会为他返回多少。为了达到效果代码可以这样书写:

public interface userMapper{
  Flux<User> getUsers();
}

在这里我们引入了一个全新的对象模型Flux,这是Reactor框架中特有的一个对象类型,它包含0到n个元素的异步序列。我们将会在《1.2Reactor框架》中详细讲解Flux。

1.1.1流

1.什么是流

简单的说流就是由生产者生产给一个或者多个消费者消费的元素的序列。像这种生产者/消费之组成的模型被称为Source/Sink模型或者发布者/订阅者模型。

关于流的处理一般有两种最基本的实现机制,一种是推模型另一种是拉模型。推模型就是由生产者推送给消费者,拉模型是由消费者主动向生产者拉取元素。

除此之外关于流的处理还有一个同步和异步的区别,如果说消费者请求生产者的元素不可用时就必须进入等待直到元素可用,这种情况我们称之为同步请求。解决这种现象就是在两端进行异步处理,生产者可以在消费者请求元素之后处理其他业务,当元素准备就绪时由生产者再异步发送给消费者。

2.流量的控制

我们再来假设一个场景,假如生产者发出的数据速度和消费者处理数据的速度不同,消费者应该采取特定的cel来消费数据流中的数据。通常情况下,如果消费者处理数据的速度快,一般不会有问题,反之,如果不进行流量的控制就会出现消费者会被生产者快速生产的数据所淹没。一般情况下流量的控制有4种情况:

a.节流

节流很简单,就是消费者直接丢弃无法消费的元素。

b.使用缓冲区

当生产者生产的数据速度比消费者处理数据的速度快时,消费者可以采用一个边缘界缓冲区来保存快速传入的元素。

image

缓冲区的作用相当于在生产者和消费者之间添加了保存并转发的一中机制,把生产者发出的数据暂时存储起来供消费者慢慢消费。

c.调用栈阻塞

调用栈阻塞是最直接的方法就是同步线程。相当于很多车行驶在同一条公路上,儿公路只有一条车道,那么排在前面的车就挡住了后面车的道路,只能等待前面的车行驶通过后撤才可以行驶。

d.使用背压

背压是一个全新的概念,意思也很明确,就是消费者需要多少生产者就生产多少,既不会出现生产者生产数据的速度比消费者过快,也不会出现生产者生产数据速度比消费者消费数据速度过慢的现象。类似于我们在银行柜台办理业务一样,只被叫好的人才可以去办理业务。

小结

本章节关于响应式编程模型和Reactor框架就暂时讲解到这里,目前我们提出了很多概念都需要加强理解,下一节我们将会全面讲解“背压”和“响应式流”这也是做好响应式微服务的关键所在。

前面几节的文字描述会比较多,但这也是我们详细了解响应式编程模型的关键和基础,希望大家坚持。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容