【微服务架构】微服务概念及SpringCloud组件介绍(一)
一、微服务架构
1、微服务架构简介
1.1、分布式:不同的功能模块部署在不同的服务器上,减轻网站高并发带来的压力。
1.2、集群:多台服务器上部署相同应用构成一个集群,通过负载均衡共同向外提供服务。
1.3、微服务:微服务架构模式就是将web应用拆分为一系列小的服务模块,这些模块可以独立地编译、部署,并通过各自暴露的API接口通讯,共同组成一个web应用。
1.4、SpringCloud是基于SpringBoot的一整套微服务框架,提供了一系列可配置的组件,如配置管理、服务发现、负载均衡、熔断器、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等。
2、微服务的特点
- 单一职责:每一个服务模块都对应单一的业务实现
- 微:服务拆分的颗粒度很小
- 面向服务:每个服务对外仅暴露服务接口API即可,不关心服务的技术实现,与技术、语言和平台无关
- 自治:服务间互相独立、互不干扰
- 团队独立
- 技术独立:提供Rest接口,面向服务即可
- 前后端分离
- 数据库分离:每个服务使用自己的数据源
- 部署独立:每个服务都是独立的组件,可复用,可替换,降低服务间的耦合
3、三者的关系
微服务是一种结构理念,设计原则,提供理论指导;
Spring Boot专注于快速、方便集成的单个微服务个体,可以基于Spring Boot快速开发单个微服务;
Spring Cloud是一个基于Spring Boot实现的服务工具治理包,专注于全局的服务治理框架。
二、Spring Cloud
1、Spring Cloud组件架构
上图中各组件的组件和运行流程如下:
- 所有请求都通过API网关来访问内部服务;
- 网关接受请求后,从注册中心获取可用服务模块;
- 由Ribbon进行负载均衡后,分发到后台的具体实例;
- 各个服务模块之间通过Feign进行通信处理业务;
- Hystrix负责处理服务超时熔断;
- Turbine监控服务间的调用和熔断相关指标。
再来看一个具体实例上的Spring Cloud服务流程:
2、Spring Cloud组件简介
2.1、主要组件简介
- Eureka,服务注册中心
- Zuul,API服务网关
- Config,分布式配置中心,支持本地仓库、SVN、Git、Jar包内配置等模式
- Dashboard,Hystrix仪表盘,监控集群模式和单点模式,其中集群模式需要收集器Turbine配合
- Ribbon,客户端负载均衡
- Feign,声明式服务调用
- Bus,消息总线
2.2、组件主要功能
Eureka和Ribbon,一个注册服务,一个消费服务。
Hystrix,为了优化Ribbon,防止整个微服务架构因为某个服务节点的问题导致崩溃,起到保险丝的作用。
Dashboard,给Hystrix统计和展示用,而且监控服务节点的整体压力和健康情况。
Turbine,集群收集器,服务于Dashboard。
Zuul,加在整个微服务最前沿的防火墙和代理器,隐藏微服务结点IP端口信息,加强安全保护。
Config,为了解决所有微服务各自维护各自的配置,设置一个统一的配置中心,方便修改配置。
Bus是因为config修改完配置后各个结点都要refresh才能生效实在太麻烦,所以交给bus来通知服务节点刷新配置的。
原文地址: https://www.cnblogs.com/iUtopia/p/11492072.html
本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
相关文章