现在微服务的很是流行,Spring Cloud 就是被称为构建分布式微服务系统的“全家桶”,它提供了一套简单易用的编程模型,使我们能在 Spring Boot 的基础上轻松地实现微服务系统的构建。那springcloud组件以及使用原理是什么?下面来我们就来给大家讲解一下。
Spring Cloud Netflix Eureka:Spring Cloud Netflix 中的服务治理组件,包含服务注册中心、服务注册与发现机制的实现。
Spring Cloud Netflix Ribbon:Spring Cloud Netflix 中的服务调用和客户端负载均衡组件。
Spring Cloud Netflix Hystrix:人称“豪猪哥”,Spring Cloud Netflix 的容错管理组件,为服务中出现的延迟和故障提供强大的容错能力。
Spring Cloud Netflix Feign:基于 Ribbon 和 Hystrix 的声明式服务调用组件。
Spring Cloud Netflix Zuul:Spring Cloud Netflix 中的网关组件,提供了智能路由、访问过滤等功能。
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 分布式链路跟踪组件,能够完美的整合 Twitter 的 Zipkin。
springcloud版本如何选择?
在使用 Spring Boot + Spring Cloud 进行微服务开发时,我们需要根据项目中 Spring Boot 的版本来决定 Spring Cloud 版本,否则会出现许多意想不到的错误。
Spring Boot 与 Spring Cloud 的版本对应关系如下表(参考自 Spring Cloud 官网)。
注意:Spring Cloud 官方已经停止对 Dalston、Edgware、Finchley 和 Greenwich 的版本更新。
除了上表中展示的版本对应关系之外,我们还可以使用浏览器访问 https://start.spring.io/actuator/info,获取 Spring Cloud 与 Spring Boot 的版本对应关系(JSON 版)。
{ …… "bom-ranges": { …… "spring-cloud": { "Hoxton.SR12": "Spring Boot >=2.2.0.RELEASE and <2.4.0.M1" , "2020.0.4": "Spring Boot >=2.4.0.M1 and <2.5.6-SNAPSHOT" , "2020.0.5-SNAPSHOT": "Spring Boot >=2.5.6-SNAPSHOT and <2.6.0-M1" , "2021.0.0-M1": "Spring Boot >=2.6.0.M1 and <2.6.0-SNAPSHOT" , "2021.0.0-SNAPSHOT": "Spring Boot >=2.6.0-SNAPSHOT" }, …… }, …… }
选择版本我们可以根据自己的需求去选择,不管选择哪个版本,springcloud都是一款基于 Spring Boot 实现的微服务框架,使用它能够使我们的开发更加高效!最后大家如果想要了解更多java架构师知识,敬请关注奇Q工具网。
推荐阅读:
spring注入对象什么时候创建?spring第一个程序怎么创建?