spring
最开始使用 spring 的时候,发现这个特别好用,最主要是把那些对象创建之前通过关键字 new 创建的方式把那些交给 spring ioc 容器来处理,其中 spring 还是使用了工厂模式来创建对应的对象。
然而这个时候需要自己写一堆配置,可能是使用 spring 的开发人员感觉这些配置麻烦,就有了后面的 spring boot。
spring boot
spring boot 最大的好处自己把市面上很多开源组件整合了,对于各种组件使用的 jar 进行了版版本适配,预定了一些开源组件的配置,使用者通过引入对应的 starter 来引入对应的组件,项目在启动时扫描指定的类路径根据自动装配指定的类来匹配对应的配置。这样一来就是开发人员遵循 spring boot 定义的规则来使用对应的组件即可。然而对于一些自定义的一些配置可能预定义的配置不能满足要求,需要自己来实现。
spring boot 1.x
基于 spring 4.x,最开始的一版。在 maven 中央仓库得知,spring 4.0.0 发布于 2013-12-12,spring boot 1.0.0 发布于 2014-04-01,时间差距不到半年。
spring boot 2.x
spring boot 1.x 的升级版
基于 spring 5.x,添加了 spring-webflux。侧重于响应式开发。在 maven 中央仓库得知,spring webflux 5.0.0 发布于 2017-09-28,spring boot 2.0.0 发布于 2018-03-01。
spring boot 3.x
源码基于 jdk 17 构建,即如果想使用这个版本,需要换 jdk 17。相对于 spring boot 2.x 的变化很大,其中如果使用 servlet 容器,包前缀由 javax 变为 jakarta。
https://blog.csdn.net/zlpzlpzyd/article/details/130524514
spring cloud
整合了市面上的开源组件,其中为了整合这些组件,自己定义了一套规则,比如服务注册与发现
其中重要的组件是
spring cloud commons 和 spring cloud context
https://spring.io/projects/spring-cloud-commons
其中重要的功能是服务发现与注册功能的接口定义
spring 官方的开发人员整合了当初正火的 netflix oss,oss 是 open source software 的简称
netflix oss
Netflix Open Source Software Center
广泛使用的组件
熔断 Hystrix
https://github.com/Netflix/Hystrix
从 2018 年开始进入维护模式,即不再更新以及有新版本。官方推荐使用 resilience4j 代替 Hystrix,目前市场上使用的还有阿里开源的 sentinel。
注册中心 eureka
https://github.com/Netflix/eureka
市场使用的还有consul、nacos
网关 zuul
https://github.com/Netflix/zuul
spring 官方开发了一个网关
https://spring.io/projects/spring-cloud-gateway
在 maven 中央仓库得知,spring cloud gateway 1.0.0 发布于 2017-11-22,晚于 spring webflux 5.0.0 发布时间 2017-09-28。
spring cloud gateway 在我接触的项目里用的多,基于 webflux 进行响应式开发。
负载均衡 ribbon
https://github.com/Netflix/ribbon
现在也进入了维护模式,为此 spring cloud 单独开发了一个组件 spring-cloud-loadbalancer。
服务访问
最开始的名字是 feign
XML
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
后面迁移到了 openfeign
XML
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
https://spring.io/projects/spring-cloud-openfeign
从 maven 仓库得知,从 2019 年开始 feign 就不更新了,openfeign 代替。
https://blog.csdn.net/u012060033/article/details/127268844
https://blog.csdn.net/justlpf/article/details/125874767
spring cloud alibaba
阿里在自己的开源产品基础上与 spring cloud 进行了整合,毕竟使用 spring 技术体系的人这么多,自己也不想丢了这个蛋糕是吧?
其中整合的组件有
注册中心 nacos
实现了 spring cloud commons 中的接口
熔断 sentinel
消息队列 rocketmq
升级问题
鉴于软件都是开发人员开发的,不可避免会考虑不周,会有一些问题,也就是可能被有的人利用。这个就关系到了升级问题。升级过程中不可避免会带来组件的兼容性问题,其中 spring boot 2.5 往上升级就有问题。