Spring Cloud

Spring Cloud

spring cloud组成

Spring Cloud 是一个基于Spring Boot实现的微服务架构开发工具。它为微服务架构中设计的配置管理、服务治理、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等操作提供了简单的开发方式。

Spring Cloud 包括了多个子项目:

  • Spring Cloud Config:配置管理工具,支持使用Git 存储配置内容,可以使用它实现应用配置的外部化存储,并支持客户端信息刷新。加密/解密配置内容等。
  • Spring Cloud Netflix: 核心组件,对多个Netflix OSS 开源套件进行整合。
  • Eureka: 服务治理组件,包括服务注册中心,服务注册与发现机制的实现。
  • Hystrix: 容错管理组件,实现断路器模式,帮助服务依赖中出现的延迟和为故障提供强大的容错能力。
  • Ribbon: 客户端负载均衡的服务调用组件。
  • Feign: 基于Ribbon和Hystrix的声明式服务调用组件。
  • Zuul: 网关组件,提供智能路由、访问过滤等功能。
  • Archaius: 外部化配置组件。
  • Spring Cloud Bus: 事件、消息总线,用于传播集群中的状态变化或事件,已触发后续的处理,比如用来动态刷新配置等。
  • Spring Cloud Cluster: 针对Zookeeper、Redis、Hazelcatst、Consul的选举算法和通用状态模式的实现。
  • Spring Cloud Stream: 通过Redis、Rabbit或者Kafka实现的消费微服务,可以通过简单的声明式模型来发送和接收消息。
  • Spring Cloud ZooKeeper: 基于ZooKeeper的服务发现和配置管理组件。

微服务架构

微服务架构就是将应用从存储开始垂直拆分成一系列小的web 服务,这些服务可以独立的编译及部署。服务之间通过各自暴露的Api 接口(诸如 RESTful API)相互通讯。

功能和使用场景

微服务化即把整个系统根据业务拆分成几个子系统,每个子系统可以部署多个应用,多个应用之间使用负载均衡
需要一个服务注册中心,所有的服务都可以在注册中心注册,负载均衡也是通过注册中心注册的服务来使用一定的策略来实现。
所有的客户端都通过同一个网关地址访问后台的服务,通过路由配置,网关来判断 一个URL请求由哪个服务处理。请求转发到服务上的时候也是使用负载均衡。
服务之间有时候也需要相互访问,例如有一个用户模块,其他服务在处理一些业务的时候,要获取用户服务的用户数据。
需要一个断路器,及时处理服务调用的超时和错误,防止由于其中一个服务的问题导致整体系统的瘫痪。

还需要一个监控功能,监控每个服务调用花费的时间等。

微服务架构

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bJw3bl0Q-1663750786224)(C:\Users\dce\AppData\Roaming\Typora\typora-user-images\1663748228356.png)]

各个组件的功能如下:

  • Eureka 负责服务的注册与发现,很好地将各服务连接起来。
  • Hystrix 负责监控服务之间的调用情况,连续失败多次进行熔断保护。
  • Hystrix dashboard,Turbine负责监控Hystrix的熔断情况并给予图形化的展示
  • Spring Cloud Config 提供了同一个的配置中心服务
  • 当配置文件发生变化的时候,Spring Cloud Bus通知各服务去获取罪行的配置信息
  • 所有对外的请求和服务,我们都通过Zuul来进行转发,起到API网关的作用。
  • 使用Sleuth+Zipkin+SpringAdmin将所有的请求数据记录下来,方便进行后续分析。

eureka

Spring Cloud 将 Eureka 与 Netflix 中的其他开源服务组件(例如 Ribbon、Feign 以及 Hystrix 等)一起整合进 Spring Cloud Netflix 模块中,整合后的组件全称为 Spring Cloud Netflix Eureka。
Eureka 是 Spring Cloud Netflix 模块的子模块,它是 Spring Cloud 对 Netflix Eureka 的二次封装,主要负责 Spring Cloud 的服务注册与发现功能。

Eureka 两大组件

Eureka 采用 CS(Client/Server,客户端/服务器) 架构,它包括以下两大组件:

  • Eureka Server:Eureka 服务注册中心,主要用于提供服务注册功能。当微服务启动时,会将自己的服务注册到 Eureka Server。Eureka Server 维护了一个可用服务列表,存储了所有注册到 Eureka Server 的可用服务的信息,这些可用服务可以在 Eureka Server 的管理界面中直观看到。
  • Eureka Client:Eureka 客户端,通常指的是微服务系统中各个微服务,主要用于和 Eureka Server 进行交互。在微服务应用启动后,Eureka Client 会向 Eureka Server 发送心跳(默认周期为 30 秒)。若 Eureka Server 在多个心跳周期内没有接收到某个 Eureka Client 的心跳,Eureka Server 将它从可用服务列表中移除(默认 90 秒)。

Eureka 服务注册与发现

Eureka 实现服务注册与发现的原理,如下图所示。

Eureka 服务注册与发现

上图中共涉及到以下 3 个角色:

  1. 搭建一个 Eureka Server 作为服务注册中心;
  2. 服务提供者 Eureka Client 启动时,会把当前服务器的信息以服务名(spring.a
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值