【云原生】Spring Cloud主要内容

SpringBoot

单体服务的基础,其设计初衷是简化Spring应用复杂的搭建及开发过程。

  1. 框架提供了一套简单的模块依赖和管理工具,从而避免了开发人员处理复杂的模块依赖和版本冲突问题
  2. 提供打包即用的Web服务,帮助开发人员快速进入开发

配置中心

Spring Cloud Config为服务组件提供一套在线的配置服务;提供搭建配置中心所需要的Server和Client。

  1. 统一配置,统一管理
  2. 自动化更新

服务注册与发现

这是通过Spring集成的Kureka或Consul实现的,包括以下功能:

  1. 服务注册,服务提供者在启动的时候主动的将自己的信息注册到注册中心
  2. 服务同步,服务提供者向单个注册中心注册之后,注册中心需要把信息同步到其他注册中心
  3. 服务续约,服务提供者注册之后,需要定时续约,主动向注册中心确认自己的状态,如果注册中心一段时间内没收到,则会认为该服务异常,主动剔除
  4. 服务启动,注册中心启动之后,主动从其他服务中更新最新的数据
  5. 服务下线,服务正常关闭之后需要给注册中心发个消息,通知注册中心自己已经下线了
  6. 服务发现,服务调用者向注册中心请求服务列表
  7. 失效剔除,剔除无法提供服务的实例

服务隔离或熔断

预备知识:雪崩效应

由Sping集成的Netflix Hystrix提供,从提高服务稳定性的角度出发,提供了以下功能:

  1. 服务熔断,发生雪崩时,及时的切断服务请求,让下游能够及时恢复
  2. 服务降级,当服务异常的时候,触发降级。使用缓存的数据,或允许部分失败,来保障基本功能可用。
  3. 依赖隔离,以线程池的使用为例,每个依赖都独立分配线程池,以保障当某一个线程池内出现任务积攒或线程没有释放的情况,其他依赖的请求不被影响
  4. 请求缓存,缓存上一次的请求结果
  5. 请求合并,上游在一次服务中由多个请求的时候,可以以提交——订阅的方式向Hystrix提交请求,Hystrix完成之后将结果合并,通过回调触发上游的后续处理流程。

服务网关

由Spring集成的Netflix Zuul提供,在服务调用中起到网关的作用,其功能包括:

  1. 请求校验,包括资源审查和身份认真
  2. 监控,为调用分析提供依据
  3. 动态路由,对外提供统一的网关服务,动态的将不同类型的请求路由到后端集群,实现对外提供统一的网关服务和对内进行有效的服务拆分。
  4. 压力测试,通过配置设置不同集群的负载流量,预估集集群容量
  5. 负载均衡
  6. 多区域弹性:跨区域进行请求路由,旨在实现ELB(Elastic load balance)使用的多样化,并保证边缘位置和使用者尽可能接近。

链路监控

Zipkin+Sleuth实现,或者pinpoint实现
为集群提供调用栈跟踪功能,能够观察到一个请求的完整生命周期,包括调用的发起服务,被调用的服务,调用耗时等。

你可能感兴趣的:(云计算,spring,Java)