【Spring Cloud】全家桶介绍(一)

摘自:https://www.cnblogs.com/iUtopia/p/11492072.html

一、微服务架构#

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来通知服务节点刷新配置的。

3、SpringCloud全家桶#

  1. 首先为了提供微服务之间的发现和注册,需要服务注册中心提供注册与发现功能,采用Eureka组件
  2. 消费者从注册中心拿到服务提供者的注册地址信息列表,为了从中选择一个提供方,避免流量集中在某台机,需要客户端负载均衡组件Ribbon
  3. 消费者得到具体提供方的地址信息后,发起远程调用,通过声明式调用组件Feign,将远程RestFul调用封装成接口调用。
  4. 在微服务架构中,为了避免某个服务挂掉后引起服务雪崩,以及做到服务端失败后快速响应,提供了服务熔断以及降级机制Hystrix组件
  5. 为了对外屏蔽内部服务调用细节,在最前沿加入网关组件,提供流量控制、身份鉴别、负载均衡等安全防护功能,采用API网关Zuul组件
  6. 随着系统访问量的增加,为避免单点的注册中心成为系统性能瓶颈,注册中心采用Eureka集群方式部署。
  7. 随着系统扩大,Eureka集群的部署以及服务模块的增多,每个模块维护各自的配置信息,复杂且容易出错,引入配置中心SpringCloud Config组件,提供统一的配置信息管理。
  8. 为了避免每次配置信息的变更都需要重启服务才能生效,引入消息总线Bus组件,提供无需重启、实时刷新配置信息等功能。

后续也会按照这个顺序逐个介绍各组件,以及各组件demo的开发搭建,最终完成一个SpringCloud全家桶demo......

原文地址:https://www.cnblogs.com/xichji/p/11736076.html

时间: 2024-11-08 17:03:33

【Spring Cloud】全家桶介绍(一)的相关文章

Spring Cloud Alibaba-MyShop-项目介绍

本节视频 [视频]Spring Cloud Alibaba-MyShop-项目介绍 开发环境 操作系统:Windows 10 Enterprise 开发工具:Intellij IDEA 数据库:MySQL 8.0.13 Java SDK:Oracle JDK 1.8.152 部署环境 操作系统:Linux Ubuntu Server 16.04 X64 虚拟化技术:VMware + Docker 项目管理工具 项目构建:Maven + Nexus 代码管理:Git + GitLab 镜像管理:D

如何掌握 Spring,Spring Boot 全家桶?系统学习 Spring 的大纲一份(实战教学)

搞个推荐! 资深的 Spring 工程师应该都知道 Spring 界的大牛丁雪丰.作为平安壹钱包的高级架构师之余,他不仅翻译了<Spring Boot 实战><Spring 攻略>两本书,还出了一门一揽子解决 Spring 全家桶的课程<玩转 Spring 全家桶>. 他在推荐自己的这门课程时说, 市面上有很多书和教程,但对于很多开发人员,在学习 Spring 的时候,难免会遇到这些问题: 官方文档虽然全面,但面对庞杂的知识体系,很多初学者一时不知该从哪里下手: 手册式

vue 全家桶介绍

Vue有著名的全家桶系列,包含了vue-router(http://router.vuejs.org),vuex(http://vuex.vuejs.org), vue-resource(https://github.com/pagekit/vue-resource).再加上构建工具vue-cli,sass样式,就是一个完整的vue项目的核心构成. 概括起来就是:.1.项目构建工具.2.路由.3.状态管理.4.http请求工具. 下面单独介绍 前言:Vue两大核心思想:组件化和数据驱动.组件化:

Spring Cloud的简单介绍

参考地址: https://mp.weixin.qq.com/s/wG4CTLORnvemkjUsZ7YP6Q 从一个例子开始 对于这样的"大"问题,通常需要拆解成小问题来回答.要说明 Spring Cloud 做了什么,就要说清楚它包含的组件都做了些什么? 如果一个个把组件罗列出来,似乎太过独立,没有关联性,缺少逻辑感.我们就从一个简单的例子开始,把这些组件像串珍珠一样串起来. 假设有一个项目,这个项目有两个服务,分别是"A"和"B": &qu

Spring Cloud学习系列第五篇【API网关服务】

这篇随笔接着学习微服务中一个比较重要的组件API网关服务.当我们微服务架构完成后最终是要提供给外部访问的,于是我们需要一个统一的访问入口,能隐藏我们内部服务URL细节,这就有点像局域网里那个网关的概念了,这是API网关服务就应运而生了.API网关作用有能为实现请求路由.负载均衡.校验过滤等基础功能,还能实现请求转发的熔断机制.服务集合等高级功能.补充下通常我们对外服务统一入口可以采用F5.Nginx等方式也能实现前面的请求路由与负载均衡,但是要实现后面功能了F5.Nginx就无能为力了吧,这就是

Spring Cloud Alibaba 新一代微服务解决方案

本篇是「跟我学 Spring Cloud Alibaba」系列的第一篇, 每期文章会在公众号「架构进化论」进行首发更新,欢迎关注. 1.Spring Cloud Alibaba 是什么 Spring Cloud Alibaba 是阿里巴巴提供的微服务开发一站式解决方案,是阿里巴巴开源中间件与 Spring Cloud 体系的融合. 马老师左手双十一,右手阿里开源组件,不仅占据了程序员的购物车,还要攻占大家的开发工具. 先说说 Spring Cloud 提起微服务,不得不提 Spring Clou

Spring Cloud 消费服务Feign(踩着坑往前爬)

Feign Spring Cloud Feign是一套基于Netflix Feign实现的声明式服务调用客户端.它使得编写Web服务客户端变得更加简单.我们只需要通过创建接口并用注解来配置它既可完成对Web服务接口的绑定.它具备可插拔的注解支持,包括Feign注解.JAX-RS注解.它也支持可插拔的编码器和解码器.Spring Cloud Feign还扩展了对Spring MVC注解的支持,同时还整合了Ribbon和Eureka来提供均衡负载的HTTP客户端实现. 分布式应用早在十几年前就开始出

Spring Cloud 微服务设计与实践

整理微服务设计与实践历程,共享给大家. 微服务的描述 The description of microserivce by Martin Fowler : 根据业务模块划分服务种类. 每个服务可以独立部署并且互相隔离. 通过轻量的 API 调用服务. 服务需要保证良好的高可用性. 微服务架构是以专注与单一责任的小功能模块为基础.通过 API 相互通信的方式完成复杂业务系统搭建的一种设计思想. 演变过程 单体架构(Monolithic) -> 垂直架构 -> SOA 架构 -> 微服务架构

Spring Cloud之——Config(配置中心)

Spring Cloud Config(配置中心) 大家好,有一段时间没有写技术博客了.由于工作上的事情,这方面很难分配时间.近几年随着服务化的兴起,一批服务化的框架应运而生,像dubbo,thrift,spring-cloud等.在国内使用dubbo的公司非常多,dubbo也是java程序员面试时必备知识点,而且它的官方文档写的非常清晰易懂,这都使得dubbo的普及非常容易.thrift是apache贡献的,似乎也流行了一段时间,小编对这个框架不是很了解.随后spring-cloud一经推出,