SpringCloud系列(一)| SpringCloud简介

上个系列中,我们已经介绍完了SpringBoot的用法,简单概述 springBoot = Spring + X, 就是对于Spring和其他技术的融合 进行了简化开发,所以x可以代表任何技术,比如 mybtis, mybatisPlus, redis.... 对于集成这些常用框架,springBoot本身就预设了一些常用技术的集成方案,对于没有预设的,也可以通过自动化配置功能,快捷融入进来。

而springCloud就是 多个SpringBoot的融合,通过多个SpringBoot模块,完成一套微服务体系的搭建,并使其具备了服务发现与注册,服务治理,服务网关,服务监控,服务间调用等等一系列功能的集合,方便开发者们很容易的搭建一套微服务框架,只需把更多的精力投入到业务层的开发当中。

SpringCloud本身不是新的框架,他是一系列框架的有机组合,利用SpringBoot 的开发便利性巧妙地简化了分布式系统基础设施的开发。并非所有的组件都是Spring提供,Netflix扮演了重要角色。

一、SpringBoot和SpringCloud区别

  • SpringBoot专注于开发方便的开发单个个体微服务;
  • SpringCloud是关注全局的微服务协调整理治理框架,它将SpringBoot开发的一个个单体微服务,整合并管理起来,为各个微服务之间提供:配置管理、服务发现、断路器、路由、为代理、事件总栈、全局锁、决策竞选、分布式会话等等集成服务;
  • SpringBoot可以离开SpringCloud独立使用,开发项目,但SpringCloud离不开SpringBoot,属于依赖关系;
  • SpringBoot专注于快速、方便的开发单个个体微服务,SpringCloud关注全局的服务治理框架;

二、SpringCloud Netflix

netflix是收费视频网站公司的名字,全球十大视频网站之一。NetFlix公司针对SpringCloud提出的规范,定义了一套自己的组件化实现,迅速在社区中得到响应并被广泛使用。 Spring Cloud Netflix是SpringCloud中的一个组件库,Spring Cloud Netflix通过自动配置和绑定到Spring环境和其他Spring编程模型习惯用法,为Spring Boot应用程序提供Netflix OSS集成。

Netflix组件提供包括服务发现(Eureka)、熔断器(Hystrix)、智能路由(Zuul)和客户端负载均衡器(Ribbon)。

但是从2016年以来,组件库中的大部分组件相继进入了维护模式,就目前来看,继续使用Sprng Cloud Netflix问题不大,但长期来看,显然是不合适的。

例如网关的组件zuul。由于Zuul持续跳票1年多,Spring Cloud索性自己开发了Spring Cloud Gateway。

但是现在很多Netflix的组件使用的热度还是很高的。例如eureka,histrix,ribbon,feign等,甚至也是可以混合使用的。

三、SpringCloud Alibaba

2019年7月24日Spring官方社区官方博文中宣布了Spring Cloud Alibaba正式从 Spring Cloud Incubator 孵化器毕业,成为了Spring社区的正式项目。同时国内版Github码云也提供了Spring Cloud Alibaba极速下载镜像。

Spring Cloud alibaba 主要功能及对应组件

  1. 服务的注册与发现(对标Netflix的Eureka译音尤睿卡): Nacos
  2. SpringCloud-dubbo: 基于dubbo协议的rpc框架,对标feign(http)
  3. 服务限流降级(即熔断限流,对标Hystrix):Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
  4. 消息驱动RocketMQ,可选消息队列,阿里出品并开源
  5. Spring Cloud Gateway: 新一代服务网关,Spring提供。
  6. 配置管理Nacos:将配置文件统一管理,支持试试刷新,灰度发布,回滚等功能
  7. 调用链监控Sleuth(不是阿里的,属于SpringCloud体系)

SpringCloud alibaba的主要技术组件我们可从官方文档的目录中查看到: 大致有如下几种,只不过我们在项目中不见得都得到。

两个技术架构比较:

由于Netflix的停止维护,所以未来的大趋势还是看好SpringCloud alibaba。 所以本系列文章主要侧重SpringCloud Alibaba的使用。后面如果有时间,也会给大家介绍一下Netflix系列组件的用法。

SpringCloud 与 SpringBoot 版本对应关系:

spring.io/projects/sp...

相关推荐
小娄写码3 分钟前
线程池原理
java·开发语言·jvm
散一世繁华,颠半世琉璃3 分钟前
SpringBoot揭秘:URL与HTTP方法如何定位到Controller
spring boot·后端·http
安晴晚风1 小时前
从0开始在linux服务器上部署SpringBoot和Vue
linux·运维·前端·数据库·后端·运维开发
陌上花开࿈5 小时前
调用第三方接口
java
Aileen_0v05 小时前
【玩转OCR | 腾讯云智能结构化OCR在图像增强与发票识别中的应用实践】
android·java·人工智能·云计算·ocr·腾讯云·玩转腾讯云ocr
桂月二二7 小时前
Java与容器化:如何使用Docker和Kubernetes优化Java应用的部署
java·docker·kubernetes
liuxin334455667 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
海绵波波1077 小时前
flask后端开发(10):问答平台项目结构搭建
后端·python·flask
小马爱打代码7 小时前
设计模式详解(建造者模式)
java·设计模式·建造者模式
栗子~~8 小时前
idea 8年使用整理
java·ide·intellij-idea