一、微服务架构

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......

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

  1. Spring Cloud全家桶主要组件及简要介绍

    一.微服务简介 微服务是最近的一两年的时间里是很火的一个概念.感觉不学习一下都快跟不上时代的步伐了,下边做一下简单的总结和介绍. 何为微服务?简而言之,微服务架构风格这种开发方法,是以开发一组小型服务 ...

  2. 【转载】Spring Cloud全家桶主要组件及简要介绍

    https://blog.csdn.net/xlgen157387/article/details/77773908

  3. Vue全家桶介绍

    一直不清楚全家桶是什么玩意,上网搜了一下,才知道就是平时项目中使用的几个依赖包,下面分享一下 Vue 全家桶介绍 Vue有著名的全家桶系列,包含了vue-router(http://router.vu ...

  4. Spring Cloud Alibaba-MyShop-项目介绍

    本节视频 [视频]Spring Cloud Alibaba-MyShop-项目介绍 开发环境 操作系统:Windows 10 Enterprise 开发工具:Intellij IDEA 数据库:MyS ...

  5. Spring Cloud 入门概括介绍

    出处: 拜托!面试请不要再问我Spring Cloud底层原理 概述 毫无疑问,Spring Cloud是目前微服务架构领域的翘楚,无数的书籍博客都在讲解这个技术.不过大多数讲解还停留在对Spring ...

  6. SpringCloud全家桶介绍及手绘架构

    文章目录 概述 一.业务场景介绍 二.Spring Cloud核心组件:Eureka 三.Spring Cloud核心组件:Feign 四.Spring Cloud核心组件:Ribbon 五.Spri ...

  7. Vue 全家桶介绍

    Vue有著名的全家桶系列,包含了vue-router(http://router.vuejs.org),vuex(http://vuex.vuejs.org), vue-resource(https: ...

  8. spring cloud之简单介绍

    以下是来自官方的一篇简单介绍: spring Cloud provides tools for developers to quickly build some of the common patte ...

  9. spring cloud 微服务介绍(转)

    一.理解微服务   我们通过软件架构演进过程来理解什么是微服务,软件架构的发展经历了从单体结构.垂直架构.SOA架构到微服务架构的过程. 1. 单体架构 1.1 特点(1)所有的功能集成在一个项目工程 ...

随机推荐

  1. mybatis动态拼接条件的技巧 where 1=1 或者where标签

    /**     * 根据输入的学生信息进行条件检索     * 1. 当只输入用户名时, 使用用户名进行模糊检索:     * 2. 当只输入邮箱时, 使用性别进行完全匹配     * 3. 当用户名 ...

  2. 《即时消息技术剖析与实战》学习笔记7——IM系统的消息未读

    一.什么是消息未读 消息未读包括会话未读和总未读.前者指的是当前用户和某一聊天方的未读消息数,后者指的是当前用户的所有未读消息数,也就是所有会话未读的和.比如用户A收到用户B的2条消息,还收到用户C的 ...

  3. go语言 链表练习

    package main import "fmt" //定义节点 type Node struct { Data int Next *Node } /* * 返回第一个节点 * h ...

  4. [Spark] 01 - What is Spark

    大数据 云计算概念 课程:Spark编程基础(Python版) 大数据4V特性 Volumn, Variety, Velocity, Value. 思维方式 通过数据发现问题,再解决问题. 速度更重要 ...

  5. UVM——寄存器模型相关的一些函数

    0. 引言 在UVM支持的寄存器操作中,有get.update.mirror.write等等一些方法,在这里整理一下他们的用法. 寄存器模型中的寄存器值应该与DUT保持同步,但是由于DUT的值是实时更 ...

  6. 对象实例Vue

    var vm = new Vue({ el:'#app', data:{}, //数据 methods:{}, //方法调用 filters:{}, //私有过滤器 directives:{}, // ...

  7. C#控件及常用属性

    1.窗体(Form) 1.常用属性 (1)Name 属性:用来获取或设置窗体的名称,在应用程序中可通过Name 属性来引用窗体. (2) WindowState 属性: 用来获取或设置窗体的窗口状态. ...

  8. 数据结构与算法(C/C++版)【排序】

    第八章<排序>  一.直接插入排序  //直接插入排序 //算法思想:每趟将一个待排的关键字按照其值的大小插入到已经排好的部分有序序列的适当位置上,直到所有待排关键字都被插入到有序序列中为 ...

  9. SpringBootSecurity学习(11)网页版登录之URL动态权限

    动态权限 前面讨论用户登录认证的时候,根据用户名查询用户会将用户拥有的角色一起查询出来,自动实现判断当前登录用户拥有哪些角色.可以说用户与角色之间的动态配置和判断security做的非常不错.不过在配 ...

  10. ThinkPHP框架快速开发网站

    使用ThinkPHP框架快速搭建网站 这一周一直忙于做实验室的网站,基本功能算是完成了.比较有收获的是大概了解了ThinkPHP框架.写一些东西留作纪念吧.如果对于同样是Web方面新手的你有一丝丝帮助 ...