Spring Cloud

Spring Cloud 简介(一)

  • 一、微服务架构概述
      • 集中式系统
      • 分布式系统
  • 二、系统进化理论背景
      • 微服务架构
  • 三、微服务架构的优缺点
  • 四、Spring Cloud是什么
  • 五、Spring Cloud的整体架构

一、微服务架构概述

在系统架构与设计的实践中,经历了两个阶段,一个阶段是早些年常见的集中式系统,一个阶段是近年来流行的分布式系统;

集中式系统

集中式系统也叫单体应用,就是把所有的程序、功能、模块都集中到一个项目中,部署在一台服务器
上,从而对外提供服务;

分布式系统

分布式系统就是把所有的程序、功能拆分成不同的子系统,部署在多台不同的服务器上,这些子系统相
互协作共同对外提供服务,而对用户而言他并不知道后台是多个子系统和多台服务器在提供服务,在使
用上和集中式系统一样;

二、系统进化理论背景

系统进化的背景与中国互联网用户规模庞大有巨大关系,中国联网用户规模有7.7亿,庞大的用户访问量对系统的架构设计是巨大的挑战;产品或者网站初期,通常功能较少,用户量也不多,所以一般按照单体应用进行设计和开发,按照经典的MVC三层架构设计;随着业务的发展,应用功能的增加,访问用户的增多,传统的采用集中式系统进行开发的方式就不再适用了,因为在这种情况下,集中式系统就会逐步变得非常庞大,很多人维护这么一个系统,开发、测试、上线都会造成很大问题,比如代码冲突,代码重复,逻辑错综混乱,代码逻辑复杂度增加,响应新需求的速度降低,隐藏的风险增大;所以需要按照业务维度进行应用拆分,采用分布式开发,每个应用专职于做某一些方面的事情,比如将一个集中式系统拆分为用户服务、订单服务、产品服务、交易服务等,各个应用服务之间通过相互调用完成某一项业务功能。

微服务架构

简单地说, 微服务是系统架构上的一种设计风格, 它的主旨是将一个原本独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间通过基于HTTP的RESTful API进行通信协作。

三、微服务架构的优缺点

1、我们知道微服务架构是将系统中的不同功能模块拆分成多个不同的服务,这些服务进行独立地开发
和部署,每个服务都运行在自己的进程内,这样每个服务的更新都不会影响其他服务的运行;
2、由于每个服务是独立部署的,所以我们可以更准确地监控每个服务的资源消耗情况,进行性能容量
的评估,通过压力测试,也很容易发现各个服务间的性能瓶颈所在;
3、由于每个服务都是独立开发,项目的开发也比较方便,减少代码的冲突、代码的重复,逻辑处理流
程也更加清晰,让后续的维护与扩展更加容易;
4、微服务可以使用不同的编程语言进行开发

四、Spring Cloud是什么

1、Spring Cloud是一个一站式的开发分布式系统的框架,为开发者提供了一系列的构建分布式系统的工具集;
2、Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(比如:配置管理,服务发现,断路器,智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等);

SpringCloud版本 SpringBoot版本

2020.0.x aka            Ilford        兼容      Spring Boot  2.4.x
						Hoxton        兼容      Spring Boot 2.2.x、Spring Boot 2.3.x
                    	Greenwich     兼容      Spring Boot 2.1.x
                     	Finchley      兼容      Spring Boot 2.0.x
                    	Edgware       兼容      Spring Boot 1.5.x
						Dalston       兼容      Spring Boot 1.5.x
						Camden        兼容      Spring Boot 1.4.x、Spring Boot 1.5.x
						Brixton       兼容      Spring Boot 1.3.x、Spring Boot 1.4.x
						Angel         兼容      Spring Boot 1.2.x
3、开发分布式系统都需要解决一系列共同关心的问题,而使用Spring Cloud可以快速地实现这些分布式开发共同关心的问题,并能方便地在任何分布式环境中部署与运行。
4、Spring Cloud这个一站式地分布式开发框架,被近年来流行的“微服务”架构所大力推崇,成为目前进行微服务架构的优先选择工具;
5、Spring Cloud基于Spring Boot框架构建微服务架构,学习Spring Cloud需要先学习Spring Boot; 

SpringCloud官网

五、Spring Cloud的整体架构

Spring Cloud_第1张图片
Service Provider: 暴露服务的服务提供方。
Service Consumer:调用远程服务的服务消费方。
EureKa Server: 服务注册中心和服务发现中心。

你可能感兴趣的:(spring)