SpringCloud核心组件讲解-程序员宅基地

技术标签: 微服务  java  spring cloud  

SpringCloud入门

一、微服务与SpringCloud
1.1 微服务

百度百科定义:“一种软件开发技术- 面向服务的体系结构(SOA)架构样式的一种变体,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。每个服务运行在其独立的进程中,服务与服务间采用轻量级的通信机制互相沟通(通常是基于HTTP的RESTful API)。每个服务都围绕着具体业务进行构建,并且能够独立地部署到生产环境、类生产环境等。”

概念:通俗的说,微服务就是“微小的服务”,微小体现在服务的体量小,复杂度低。所谓的“服务”,是指完成某一项功能的模块。它的代码量小,易于维护。它可以帮助用户解决一个或一组问题,多个微服务组成的微服务架构是新兴架构。

优点

  • 微服务具有良好的可扩展性,随着业务的增加,微服务的体积和代码量都会急剧增加。此时,我们可以根据业务再次拆分微服务。
  • 微服务可独立开发、部署和运行,且代码量较少,因此启动和运行速度较快。
  • 微服务通常部署在容器上,实现快速构建和部署。
  • 微服务还具有良好的故障隔离能力,服务之间耦合度低。当应用程序中某个微服务发生故障时,不会波及其他服务而导致系统瘫痪。
1.2 SpringCloud

概念:SpringCloud是一款基于Spring Boot实现的微服务框架。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发。服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。

组成:SpringCloud包含七大组件,负责不同的功能实现,分别是Eureka、Ribbon、Feign、Hystrix、Config、Zuul、Bus。一个典型的SpringCloud组件使用,架构图如下所示:

在这里插入图片描述

SpringCloud实现:SpringCloud并不是一个拿来即用的框架,它是一种微服务规范,它有两代实现,第一代实现,是SpringCloud Netflix。第二代实现,是SpringCloud Alibaba。

二、SpringCloud组件
2.1 SpringCloud组件总览

​ SpringCloud 包括 Spring Cloud Gateway、Spring Cloud Config、Spring Cloud Bus 等近 20 个服务组件,这些组件提供了服务治理、服务网关、智能路由、负载均衡、熔断器、监控跟踪、分布式消息队列、配置管理等领域的解决方案,它的常用组件如下表所示:

SpringCloud组件 描述
Spring Cloud Netflix Eureka Spring Cloud Netflix 中的服务治理组件,包含服务注册中心、服务注册与发现机制的实现。
Spring Cloud Netflix Ribbon Spring Cloud Netflix 中的服务调用和客户端负载均衡组件,它基于HTTP和TCP实现。微服务间的调用,API网关的请求转发等内容,实际上都是通过Ribbon来实现的,包括后续将要的Feign,它也是基于Ribbon实现的工具。
Spring Cloud Netflix Hystrix 防止服务故障“雪崩”效应,Spring Cloud Netflix 的容错管理组件,为服务中出现的延迟和故障提供强大的容错能力。
Spring Cloud Netflix Feign Feign是一个声明性web服务客户端,基于 Ribbon 和 Hystrix 的声明式服务调用组件。
Spring Cloud Netflix Zuul Spring Cloud Netflix 中的网关组件,它的核心是一系列Filters,提供了智能路由、访问过滤等功能。
Spring Cloud Gateway 一个基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技术开发的网关框架,它使用 Filter 链的方式提供了网关的基本功能,例如安全、监控/指标和限流等。
Spring Cloud Config Spring Cloud 的配置管理工具,支持使用 Git 存储配置内容,实现应用配置的外部化存储,并支持在客户端对配置进行刷新、加密、解密等操作。
Spring Cloud Bus Spring Cloud 的事件和消息总线,主要用于在集群中传播事件或状态变化,以触发后续的处理,例如动态刷新配置。
Spring Cloud Stream Spring Cloud 的消息中间件组件,它集成了 Apache Kafka 和 RabbitMQ 等消息中间件,并通过定义绑定器作为中间层,完美地实现了应用程序与消息中间件之间的隔离。通过向应用程序暴露统一的 Channel 通道,使得应用程序不需要再考虑各种不同的消息中间件实现,就能轻松地发送和接收消息。
Spring Cloud Sleuth Spring Cloud 分布式链路跟踪组件,通过Sleuth可以很清楚的了解到一个服务请求经过了哪些服务,每个服务处理花费了多长。
2.2 五大核心组件

​ SpringCloud微服务框架的五大核心组件分别是:Eureka、Ribbon、Feign、Hystrix、Gateway,下面分别介绍这五个组件。

2.2.1 Eureka

​ 在分布式微服务架构中,服务众多,如何确定哪台服务器对应哪个服务,Eureka就是这样一个组件,用于服务注册与发现。Eurake分为两大组成部分,Eureka客户端负责将信息注册到Eureka服务端内,Eureka服务端内有注册表,相当于注册中心,连接各个服务,如下图所示:

在这里插入图片描述

2.2.2 Ribbon

​ 在分布式微服务架构中,为了保证高可用性,通常采用集群架构。一个服务通常布置在多个服务器节点上,通过Ribbon可以起到负载均衡的效果,采用轮询算法,选择最终的服务器节点。下图,表示它的使用:

在这里插入图片描述

2.2.3 Feign

​ Feign是一个声明性web服务客户端,通过Eureka知道各个服务的位置后,可以通过Feign调用服务。只需要在调用服务的地方,写上对应的注解。Fegin会根据注解,与指定的服务建立连接、发起请求、获取响应、解析响应等。Feign底层是动态代理,它的工作流程可以用下图表示:

在这里插入图片描述

2.2.4 Hystrix

​ Hystrix是一个容错管理组件,为服务中出现的延迟和故障提供强大的容错能力。Hystrix是隔离、熔断以及降级的一个框架,能够防止雪崩效应。在一个APP中,通常需要使用到多个服务,多线程高并发的情况下,如果某一个服务环节阻塞出错。Hystrix可以熔断和降级,不至于什么都不做,最后返回一个超时异常,工作原理如下图所示:

在这里插入图片描述

2.2.5 Gateway

​ Gateway是一个基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技术开发的网关框架,它使用 Filter 链的方式提供了网关的基本功能,例如安全、监控/指标和限流等。zull也是一个网关组件,它的核心是一系列Filters,提供了智能路由、访问过滤等功能。由于微服务架构中,服务众多,有时候甚至上百个服务。前端直接访问服务不大现实,这时候可以交给zull,它会根据请求中的一些特征转发给后台的各个服务。Gateway也是API网关的一种实现,它的工作流程如下图所示:

在这里插入图片描述

2.3 其余组件
Config与Bus组件

​ 在分布式微服务架构中,服务的数量以及配置信息日益增多,比如各种服务器参数配置、各种数据库访问参数配置、各种环境下配置信息的不同、配置信息修改之后实时生效等等,传统的配置文件方式或者将配置信息存放于数据库中的方式已无法满足开发人员对配置管理的要求。

​ Spring Cloud Bus 使用一个轻量级的消息代理来构建一个公共的消息主题 Topic(默认为“springCloudBus”),这个 Topic 中的消息会被所有服务实例监听和消费。当其中的一个服务刷新数据时,Spring Cloud Bus 会把信息保存到 Topic 中,这样监听这个 Topic 的服务就收到消息并自动消费。它们的使用如下图所示:

在这里插入图片描述

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_44183721/article/details/126274228

智能推荐

Android:利用Java反射调用@hide的API_connectivitymanager 反射-程序员宅基地

文章浏览阅读1.6w次,点赞4次,收藏13次。设置使用3G数据功能:从源代码看到隐藏的API(ConnectivityManager.java): /** * Sets the persisted value for enabling/disabling Mobile data. * * @param enabled Whether the mobile data connection should_connectivitymanager 反射

[渝粤教育] 中国地质大学 互换性与测量技术 复习题 (2)_要求两孔同轴度φ0.3mm最大偏差是多少-程序员宅基地

文章浏览阅读941次。《互换性与测量技术》模拟题一.单选题1.优先选用基孔制的原因是().A.孔比轴难加工B.减少定尺寸孔用刀具量具的规格和数量C.减少孔和轴的公差带数量D.从工艺上讲应先加工孔后加工轴2.评定齿轮传递运动准确性的指标是().A.齿距累积总偏差B.单个齿距偏差C.齿廓总偏差D.螺旋线总偏差3.当几何公差框格的指引线箭头与尺寸线对齐时所表示的被测要素是().A.轮廓要素B.单一要素C.中心要素D.基准要素4.螺纹代号M20×2-7g6g表示的螺纹是().A.粗牙普通外螺纹B.粗_要求两孔同轴度φ0.3mm最大偏差是多少

Simulink模型转为TwinCAT3可以运行的ST程序_simulink导入到twincat-程序员宅基地

文章浏览阅读1k次。@Simulink PLC Coder :将Simulink模型转为TwunCAT程序1 先把simulink程序封装为一个子系统subsystem,标注好输入输出端口参考链接:https://ww2.mathworks.cn/help/plccoder/ug/plc-coder-general.html#bsemuq2-12 程序内不能包含任何连续状态的模块(比如微分,积分模块),而且有不支持的等simulink模块(比如Clock模块),因此需要用离散状态的功能块替代,或者编写MATLAB _simulink导入到twincat

程序员35岁真的是分水岭吗?复习指南_程序员35岁为什么会是一个分水岭-程序员宅基地

文章浏览阅读100次。缘起随着互联网企业的不断发展,产品项目中的模块越来越多,用户体验要求也越来越高,想实现小步快跑、快速迭代的目的越来越难,还有应用之间的互相调用等等问题,插件化技术应用而生。如果没有插件化技术,美团、淘宝这些集成了大量“app”的应用,可能会有几个g那么大。所以,当今的Android移动开发,不会热修复、插件化、组件化,80%以上的面试都过不了。阿里P8大佬每天熬夜到凌晨一两点,花了将近半个月时间将Android热修复框架、插件化框架、组件化框架、图片加载框架、网络访问框架、RxJava响应式编程框架、_程序员35岁为什么会是一个分水岭

echarts全国地图点击弹窗(Vue)_echarts地图点击弹出窗体明细-程序员宅基地

文章浏览阅读5k次,点赞2次,收藏18次。实现echart 全国地图点击标记有弹窗_echarts地图点击弹出窗体明细

408计组大题-----I/O大题(二)_异步串行通信方式408-程序员宅基地

文章浏览阅读309次。本题第(1)题所考的I/O模式为程序中断方式,我们做如下对知识点的回顾:1.I/O接口的数据缓冲区满,I/O接口给CPU发送I/O中断信号,CPU检测到I/O中断后进行中断处理①中断响应(中断隐指令)②中断服务程序程序中断方式的CPU取数据时间 = ① + ②本题第(2)题所考的I/O模式为DMA方式,我们做如下对知识点的回顾:1.I/O接口与主机之间交换数据方式为以块为单位,I/O设备与I/O接口交换数据方式为以字为单位,传输过程为。_异步串行通信方式408

随便推点

Win10解决Disciples 2圣战群英传2卡顿问题_disciples 2如何窗口化运行-程序员宅基地

文章浏览阅读5.9k次。最近想翻点老游戏出来玩,比如圣战群英传2,但是卡得我mmp,一通搜索和捣鼓之后,终于发现了比较简单的解决问题的方法。1、首先确认电脑中是否有vcredist2010,至少08年以后的VC++库,没有就安。2、检查游戏根目录下有没有d3d9.dll,没有就下方传送门。https://dl.pconline.com.cn/download/91252.html如果还没能解决问题,那么:3、看看根目录有没有Disciple.ini,如果没有:3.1、看看根目录有没有一个骷髅头头像的Importer.e_disciples 2如何窗口化运行

数据链路层循环冗余(CRC)检验_链路层循环冗余校验码是检验哪一部分-程序员宅基地

文章浏览阅读5.5k次。数据链路层有许多协议,但有三个基本问题是相同的:封装成帧、透明传输和差错检验。为了保证数据传输的可靠性,在计算机网络传输数据时,必须采用各种差错检验措施,目前广泛使用的是循环冗余(CRC)检验的检错技术。 CRC检验原理: 在发送端,先把数据划分为组,假定每个组k个比特。现假定待传送的数据M=101001(k=6)。CRC运算就是在数据M后面添加供差错检验用的n位冗余码,然后构成一个帧发送出去,_链路层循环冗余校验码是检验哪一部分

Spring Security(08)——intercept-url配置_intercept-url j_spring_security_logout-程序员宅基地

文章浏览阅读1w次。Spring Security介绍系列文章。本文主要介绍如何通过intercept-url配置来实现对特定的URL进行拦截,包括指定访问权限、指定访问协议、指定请求方法_intercept-url j_spring_security_logout

iserdese2接口详解_Xilinx 7系列FPGA之SelectIO(3)——高级IO逻辑资源简介-程序员宅基地

文章浏览阅读1.7k次。上一篇咱们介绍了IO逻辑资源,本篇咱们来聊一聊高级的IO逻辑资源,即ISERDESE2模块和OSERDESE2模块。所谓ISERDESE2模块,即Input serial-to-parallel converters。该模块的作用就是实现高速源同步输入数据的串并转换。所谓OSERDESE2模块,即output parallel-to-serial converters。该模块的作用就是实现高速源同..._iserdese2用法

服务没有注册到nacos的原因分析_服务注册不到nacos-程序员宅基地

文章浏览阅读6.9k次,点赞9次,收藏4次。服务没有注册到nacos的原因分析因为没有加上版本号,导致不能注册。 <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>0.2.1.RELEASE<_服务注册不到nacos

Android应用去掉标题栏状态栏(Android Studio)_android studio 应用禁用状态栏-程序员宅基地

文章浏览阅读442次。**网上关于Android Studio的教程比较少,去掉标题栏的方法大多不能直接使用。 在Android Studio中其实更简单一些,在app/res/values/styles.xml文件中加个标签就可以了**true 完整代码如下,可以看到这段代码放在什么位置。

推荐文章

热门文章

相关标签