共计 3088 个字符,预计需要花费 8 分钟才能阅读完成。
Spring Cloud 微服务总体架构图
架构组件解释
1、Sleuth- 链路跟踪
- 为服务之间调用提供链路追踪。通过 Sleuth 可以很清楚的了解到一个服务请求经过了哪些服务,每个服务处理花费了多长。从而让我们可以很方便的理清
各微服务间的调用关系
;
2、断路器(Hystrix)
- 在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用 (RPC),在 Spring Cloud 可以用 RestTemplate+Ribbon 和 Feign 来调用。
为了保证其高可用,单个服务通常会集群部署。由于网络原因或者自身的原因,服务并不能保证 100% 可用,如果单个服务出现问题,调用这个服务就会出现线程阻塞,此时若有大量的请求涌入,Servlet 容器的线程资源会被消耗完毕,导致服务瘫痪
。服务与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重后果,这就是服务故障的“雪崩”效应。 - Netflix 开源了 Hystrix 组件,实现了断路器模式,SpringCloud 对这一组件进行了整合;
3、Turbine 集群监控
- Turbine 是聚合服务器发送事件流数据的一个工具,用来监控集群下 hystrix 的 metrics 情况。通过 turbine 可以监控集群的请求量,可以知道系统的请求高峰期,从而更好的知道系统的短板在哪里。
4、Consul 服务治理 和 Eureka 服务治理
- 由于 Spring Cloud 为服务治理做了一层抽象接口,所以在 Spring Cloud 应用中可以支持多种不同的服务治理框架,比如:
Netflix Eureka、Consul、Zookeeper
。 - Spring Cloud Consul 项目是针对 Consul 的服务治理实现。Consul 是一个分布式高可用的系统,它包含多个组件,但是作为一个整体,在微服务架构中为我们的基础设施提供服务发现和服务配置的工具。它包含了下面几个特性:
服务发现、健康检查、Key/Value 存储、多数据中心。
- 由于 Consul 自身提供了服务端,所以我们不需要像之前实现 Eureka 的时候创建服务注册中心,直接通过下载 consul 的服务端程序就可以使用。Consul 比 Eureka 注册支持的更多一些。
5、config 配置管理
- 引入 spring cloud config 后,我们的外部配置文件就可以集中放置在一个 git 仓库里,再新建一个 config server,用来管理所有的配置文件,维护的时候需要更改配置时,只需要在本地更改后,推送到远程仓库,所有的服务实例都可以通过 config server 来获取配置文件,这时每个服务实例就相当于配置服务的客户端 config client, 为了保证系统的稳定,配置服务端 config server 可以进行集群部署。
6、Nginx
- 用来做反向代理、负载均衡,当有请求的时候,根据配置的调度策略(加权轮询、IP 哈希、最少连接数、一致性哈希)给请求者返回相应的服务器 IP。
7、Zuul 服务网关
- Zuul 的核心是一系列的 filters, 其作用可以类比 Servlet 框架的 Filter;
- Zuul 的主要功能是路由和过滤器。是各种服务的统一入口,同时还会用来提供监控、授权、安全、调度等等;可以通过扩展 ZuulFilter,在执行方法之前,做各种检查工作。
一、微服务的简介
微服务英文名称(Microservice),Microservice 架构模式就是将整个 Web 应用组织为一系列小的 Web 服务。这些小的 Web 服务可以独立地编译及部署,并通过各自暴露的 API 接口相互通讯。它们彼此相互协作,作为一个整体为用户提供功能,却可以独立地进行扩展。
微服务架构需要的功能或使用场景
- 我们把整个系统根据业务拆分成几个子系统。
- 每个子系统可以部署多个应用,多个应用之间使用负载均衡。
- 需要一个服务注册中心,所有的服务都在注册中心注册,负载均衡也是通过在注册中心注册的服务来使用一定策略来实现。
- 所有的客户端都通过同一个网关地址访问后台的服务,通过路由配置,网关来判断一个 URL 请求由哪个服务处理。请求转发到服务上的时候也使用负载均衡。
- 服务之间有时候也需要相互访问。例如有一个用户模块,其他服务在处理一些业务的时候,要获取用户服务的用户数据。
- 需要一个断路器,及时处理服务调用时的超时和错误,防止由于其中一个服务的问题而导致整体系统的瘫痪。
- 还需要一个监控功能,监控每个服务调用花费的时间等。
目前主流的微服务框架:Dubbo、SpringCloud、thrift、Hessian 等,目前国内的中小企业用的大多数都是 Dubbo,SpringCloud。
二:SpringCloud 项目简介
* SpringCloud 是基于 SpringBoot 的一整套实现微服务的框架。他提供了微服务开发所需的配置管理、服务发现、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等组件。
* 最重要的是,跟 spring boot 框架一起使用的话,会让你开发微服务架构的云服务非常好的方便。SpringBoot 旨在简化创建产品级的 Spring 应用和服务,简化了配置文件,使用嵌入式 web 服务器,含有诸多开箱即用微服务功能;
Spring Cloud 子项目包括:
- Spring Cloud Config:配置管理开发工具包,可以让你把配置放到远程服务器,目前支持本地存储、Git 以及 Subversion。
- Spring Cloud Bus:事件、消息总线,用于在集群(例如,配置变化事件)中传播状态变化,可与 Spring Cloud Config 联合实现热部署。
Spring Cloud Netflix:针对多种 Netflix 组件提供的开发工具包,其中包括 Eureka、Hystrix、Zuul、Archaius 等。
- Netflix Eureka:
云端负载均衡
,一个基于 REST 的服务,用于定位服务,以实现云端的负载均衡和中间层服务器的故障转移。 - Netflix Hystrix:
容错管理工具
,旨在通过控制服务和第三方库的节点, 从而对延迟和故障提供更强大的容错能力。 - Netflix Zuul:
边缘服务工具
,是提供动态路由,监控,弹性,安全等的边缘服务。 - Netflix Archaius:配置管理 API,包含一系列配置管理 API,提供动态类型化属性、线程安全配置操作、轮询框架、回调机制等功能。
- Netflix Eureka:
- Spring Cloud for Cloud Foundry:通过 Oauth2 协议绑定服务到 CloudFoundry,CloudFoundry 是 VMware 推出的开源 PaaS 云平台。
- Spring Cloud Sleuth:日志收集工具包,封装了 Dapper,Zipkin 和 HTrace 操作。
- Spring Cloud Data Flow:大数据操作工具,通过命令行方式操作数据流。
- Spring Cloud Security:安全工具包,为你的应用程序添加安全控制,主要是指 OAuth2。
- Spring Cloud Consul:封装了 Consul 操作,consul 是一个服务发现与配置工具,与 Docker 容器可以无缝集成。
- Spring Cloud Zookeeper:操作 Zookeeper 的工具包,用于使用 zookeeper 方式的服务注册和发现。
- Spring Cloud Stream:数据流操作开发包,封装了与 Redis,Rabbit、Kafka 等发送接收消息。
- Spring Cloud CLI:基于 Spring Boot CLI,可以让你以命令行方式快速建立云组件。
三:SpringCloud 特点
- 约定优于配置
- 开箱即用、快速启动
- 适用于各种环境
- 轻量级的组件
- 组件支持丰富,功能齐全
正文完