SpringCloud概述

简介: /

1.SpringCloud诞生
基于前面章节,我们深知微服务已成为当前开发的主流技术栈,但是如dubbo、zookeeper、nacos、rocketmq、rabbitmq、springboot、redis、es这般众多技术都只解决了一个或一类问题,微服务并没有一个统一的解决方案。开发人员或架构师想要做架构设计或系统拆分时,还需要深度调研技术选项。那么有没有一个技术可以一呼百应,做到一个彻底的解决方案呢?于是Spring团队推出了他们的微服务解决方案-Spring Cloud。

2.SpringCloud特点
作为一款优秀的微服务解决方案,其主要特点如下
约定大于配置
组件丰富,功能齐全
灵活,开箱即用,快速启动
完美适配云环境软件架构的云原生应用
3.SpringCloud版本
Spring-Cloud的github仓库:https://github.com/spring-cloud
大多数Spring项目版本号是:主版本号.次版本号.增量版本号.里程碑版本号,如Spring版本:4.3.1.RELEASE,其中主版本号标识重大重构,次版本号标识新特性调整,增量版本号一般标识bug-fix,里程碑则标识某版本号的里程碑,也可以没有。
Spring Cloud通过伦敦地铁站的形式进行命名,如下Hoxton.SR12(Hoxton:主版本号,SR:Service Release,X数字:次版本号)。

RELEASE TRAIN

BOOT VERSION

2022.0.X AKA KILBURN

3.0.X

2021.0.X AKA JUBILEE

2.6.X,2.7.X(STARTING WITH 2021.0.3)

2.4.X,2.5.X (STARTING WITH 2020.0.3)

2020.0.X AKA LLFORD

2.2.X,2.3.X(STARTING WITH SR5)

HOXTON

2.1.X

GREENWICH

FINCHLEY

2.0.X

1.5.X

EDGWARE

1.5.X

DALSTON


因为Spring Cloud是一个大综合性的项目,包含很多子项目,由于子项目也维护着自己的版本号,所以通过这种命名形式定义版本号,避免与子项目版本冲突。
更多Spring Cloud版本演进计划请移步:github里程碑仓库
4.SpringCloud子项目
https://spring.io/projects/spring-cloud#overview

HEAR FROM THE SPRING TEAM THIS JANUARY AT SPRINGONE.>

SPRING

PROJECTS

TRAINING

COMMUNITY

WHY SPRING

SUPPORT

LEARN

BY VMWARE TANZU

SPRING CLOUD

SPRING BOOT

2022.0.0

SPRING FRAMEWORK

SPRING DATA

LEARN

SAMPLES

OVERVIEW

SPRING CLOUD

SPRING CLOUD AZURE

SPRING CLOUD PROVIDES TOOLS FOR DEVELOPERS TO QUICKLY BUILD SOME OF THE COMMON PATTERNS IN DISTRIBUTE

SPRING CLOUD ALIBABA

SYSTEMS (E.S. CONFIGURATION MANAGEMENT SERVICE DISCOVERY, CIRCUIT BREAKERS, INTELLIGENT ROUTING, MICR

SPRING CLOUD FOR AMAZON

WEB SERVICES

PROXY,CONTROL BUS,ONE-TIME TOKENS.GLOBAL LOCKS, LEADERSHIP ELECTION, DISTRIBUTED SESSIONS,CLUSTE),

COORDINATION OF DISTRIBUTED SYSTEMS LEADS TO BOILER PLATE PATTERNS, AND USING SPRING CLOUD DEVELOPER

SPRING CLOUD BUS

QUICKLY STAND UP SERVICES AND APPLICATIONS THAT IMPLEMENT THOSE PATTERNS. THEY WILL WELL IN ANY

SPRING CLOUD CIRCUIT BREAKER

DISTRIBUTED ENVIRONMENT INCLUDING THE DEVELOPERS OWN LAPTOP, BARE METAL DATAL DATA CEND MANAGED

SPRING CLOUD CLI

PLATFORMS SUCH AS CLOUD FOUNDRY.

SPRING CLOUD FOR CLOUD

FOUNDRY

FEATURES

SPRING CLOUD-CLOUD

FOUNDRY SERVICE BROKER

SPRING CLOUD FOCUSES ON PROVIDING GOOD OUT OUT OF BOX EXPERIENCE FOR TYPICAL USES AND EXTENSIBILITY

SPRING CLOUD COMMONS

MECHANISM TO COVER OTHERS.

SPRING CLOUD CONFIG

DISTRIBUTED/VERSIONED CONFIGURATION

SPRING CLOUD CONNECTORS

SPRING CLOUD CONSUL

SERVICE REGISTRATION AND DISCOVERY

SPRING CLOUD CONTRACT

ROUTING

SPRING CLOUD FUNCTION

SPRING CLOUD GATEWAY

SERVICE-TO-SERVICE CALLS

SPRING CLOUD GCP

LOAD BALANCING

SPRING CLOUD KUBERNETES

CIRCUIT BREAKERS

SPRING CLOUD NETFLIX

SPRING CLOUD OPEN SERVICE

GLOBAL LOCKS

BROKER

SPRING CLOUD OPENFEIGN

LEADERSHIP ELECTION AND CLUSTER STATE


5.SpringCloud/SpringBoot版本兼容关系

RELEASE TRAIN

BOOT VERSION

2.4.X

2020.0.X AKA LLFORD

2.2.X,2.3.X(STARTING WITH SR5)

HOXTON

2.1.X

GREENWICH

FINCHLEY

2.0.X

EDGWARE

1.5.X

DALSTON

1.5.X


6.SpringCloud Alibaba诞生
随着淘系业务的发展,阿里巴巴内部针对Spring Cloud做了自身吸收后,也贡献出优秀的Spring Cloud Alibaba解决方案,应运而生孵化出如Nacos这般优秀的中间件,并被Spring Cloud官方认可。至此Spring Cloud作为微服务解决方案的实际落地场景得到了更为强有力的论证,落地方案也就清晰明了

技术

Spring Cloud官方套件或第三方套件

Alibaba套件

Netflix套件

服务注册与服务发现

Consul、Zookeeper

Nacos

Eureka

配置中心

Spring Cloud Config

Nacos

服务通信

Open Feign

Dubbo

Feign

负载均衡器

Loadbalancer

Ribbon

服务网关

Spring Cloud Gateway

Zuul

断路器

Resilience4j

Sentinel

Hystrix

链路追踪

Spring Cloud Sleuth、Zipkin

分布式事务

Seata

Spring Cloud Alibaba提供的核心组件如下:
Sentinel:阿里开源产品,可作为断路器,也支持流量控制和服务降级。
Nacos:阿里开源产品,服务注册与服务发现,同时也可作为配置中心。
RocketMQ:阿里开源的分布式消息和流计算平台。
Dubbo:阿里开源产品,高性能Java RPC框架,服务通信组件。
Seata:阿里开源产品,一个易使用的高性能微服务分布式事务解决方案。
7.为什么选择SpringCloud Alibaba
基于上述描述,读者应该会发现SpringCloud可以选择Alibaba或Netflix套件整合出一套完整解决方案。然后Netflix由于种种原因退出了维护更新的舞台,后续SpringCloud也逐步将其提供的组件一一剔除。
依附着阿里2015-2020的黄金飞速发展,Alibaba与Spring Cloud社区的强强联合,更多、更为全面的解决方案经过无数次的验证是真实可行的,同时阿里提供的开源产品保证了SpringCloud的功能又得到了进一步的补充。
所以最终我们也将选择SpringCloud Alibaba作为技术栈进行学习和演练。
8.总结
本节笔者介绍了SpringCloud诞生的由来,以及目前国内主要流行的SpringCloud Alibaba与SpringCloud的关系,同时针对SpringCloud自身的特点、版本号、依赖关系做了概要论述,这些都是为了接下来的实战打好基础。
思考问题
SpringCloud特性?
SpringCloud Alibaba与SpringCloud什么关系?
9.推荐阅读资料
浏览Spring Cloud仓库:https://github.com/spring-cloud
浏览Spring Cloud官网:https://spring.io/projects/spring-cloud
截图软件:

xsnip_1.1.0.4.zip(360 KB)

1 人点赞

1

油炸小波

2023-02-14 19:24

1625

0

举报

分享到:

注册 / 登录 语雀进行评论

关于语雀使用帮助数据安全服务协议English快速注册

油炸小波

微服务技术栈

搜索Ctrl + J

首页

目录

Git代码提交规范

什么是RESTful

负载均衡算法

Jmeter快速入门

@RefreshScope热更新原理

什么是跨域

什么是WebFlux

虚拟机安装(CentOS7)

基础篇

持久层框架MyBatisPlus

微服务框架SpringCloud

微服务概述

SpringCloud概述

SpringCloud工程部署启动

Eureka服务注册与发现

Ribbon负载均衡

Nacos注册中心

练习

Nacos配置中心

Feign远程调用

Gateway服务网关

练习

容器引擎Docker

消息中间件RabbitMQ(基础)

高级篇

SpringCloud(2025)

大纲

1.SpringCloud诞生

2.SpringCloud特点

3.SpringCloud版本

4.SpringCloud子项目

5.SpringCloud/SpringBoot版本兼容关系

6.SpringCloud Alibaba诞生

7.为什么选择SpringCloud Alibaba

8.总结

9.推荐阅读资料

相关文章
|
SQL 前端开发 API
关于ElementUI之动态树+数据表格+分页实例
关于ElementUI之动态树+数据表格+分页实例
810 0
|
消息中间件 JSON Java
Spring Boot、Spring Cloud与Spring Cloud Alibaba版本对应关系
Spring Boot、Spring Cloud与Spring Cloud Alibaba版本对应关系
32616 0
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
|
Java Serverless 数据库连接
nacosjar包运行问题之报错何解决?
Nacos是一个开源的、易于部署的动态服务发现、配置管理和服务管理平台,旨在帮助微服务架构下的应用进行快速配置更新和服务治理;在实际运用中,用户可能会遇到各种报错,本合集将常见的Nacos报错问题进行归纳和解答,以便使用者能够快速定位和解决这些问题。
620 97
|
JSON Java 网络架构
elasticsearch学习四:使用springboot整合 rest 进行搭建elasticsearch服务
这篇文章介绍了如何使用Spring Boot整合REST方式来搭建和操作Elasticsearch服务。
434 4
elasticsearch学习四:使用springboot整合 rest 进行搭建elasticsearch服务
|
Web App开发 JavaScript Java
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
这篇文章是关于如何使用Spring Boot整合Elasticsearch,并通过REST客户端操作Elasticsearch,实现一个简单的搜索前后端,以及如何爬取京东数据到Elasticsearch的案例教程。
920 0
elasticsearch学习五:springboot整合 rest 操作elasticsearch的 实际案例操作,编写搜索的前后端,爬取京东数据到elasticsearch中。
|
JSON 前端开发 数据格式
使用 el-tree 实现计算每个非叶子节点的后代节点的个数并显示
本文介绍了如何使用ElementPlus的`el-tree`组件实现计算并显示每个非叶子节点后代节点的个数,以及后代节点中ID为一万倍数的个数。
496 1
使用 el-tree 实现计算每个非叶子节点的后代节点的个数并显示
Element table组件封装 核心:父子组件传值、传方法
本文介绍了如何基于Element UI的table组件进行二次封装,创建一个具有父子组件传值和传方法功能的自定义表格组件,并提供了封装后的组件如何引入、注册和使用的方法。
395 0
Element table组件封装 核心:父子组件传值、传方法
|
应用服务中间件 nginx
nginx error日志 client intended to send too large body: 1434541 bytes 如何处理?
【8月更文挑战第27天】nginx error日志 client intended to send too large body: 1434541 bytes 如何处理?
1028 6
|
负载均衡 Java 应用服务中间件
2w字Spring Cloud最全面试题整理,全是硬货
2w字Spring Cloud最全面试题整理,全是硬货
519 1