SpringCloud 微服务(架构篇)

SpringCloud 微服务(架构篇)


软件架构的进化


什么是软件架构

  • 软件架构是在软件的内部,经过<mark>综合各种因素</mark>的考量、权衡,<mark>选择特定的技术</mark>,将系统<mark>划分成不同的部分</mark>并使这些部分相互分工,彼此协作,为用户提供需要的价值

有哪些因素

  • 业务需求
  • 技术栈
  • 成本
  • 组织架构
  • 可扩展性
  • 可维护性

架构演进

image

  • 单一应用架构
    image

  • 垂直应用架构
    image

  • 分布式服务架构
    image

  • 流动计算架构
    image

单体架构

  • 优点
    • 容易测试
    • 容易部署
  • 缺点
    • 开发效率低
    • 代码维护难
    • 部署不灵活
    • 稳定性不高
    • 扩展性不强

分布式定义

  • 旨在支持应用程序和服务的开发,可以利用物理架构,由多个自治的处理元素,不共享主内存,但通过网络发送消息合作

什么是微服务

  • 在此引用 ThoughtWorks 公司的首席科学家 Martin Fowler 的一段话:

  • In short, the microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. These services are built around business capabilities and independently deployable by fully automated deployment machinery. There is a bare minimum of centralized management of these services, which may be written in different programming languages and use different data storage technologies.

  • 谷歌翻译如下:
    • 简而言之,微服务<mark>架构风格</mark>是一种将单个应用程序作为<mark>一套小型服务开发</mark>的方法,每种应用程序都在<mark>自己的进程</mark>中运行,并与<mark>轻量级机制</mark>(通常是HTTP资源API)进行通信。 这些服务是<mark>围绕业务功能</mark>构建的,可以通过全自动部署机制<mark>独立部署</mark>。 这些服务的集中管理最少,可以用不<mark>同的编程语言</mark>编写,并使用<mark>不同的数据存储</mark>技术。

  • 微服务是一种架构风格
  • 一系列微小的服务共同组成
  • 跑在自己的进程里
  • 每个服务为独立的业务开发
  • 独立部署
  • 独立数据
  • 服务间可以是不同语言

微服务的特征

  • 单一职责
  • 轻量级通讯
  • 隔离性
  • 有自己的数据
  • 技术多样性

微服务兴起的原因

  • 互联网行业的快速发展
  • 敏捷开发,精益方式深入人心
  • 容器技术的成熟

微服务架构的优势和不足

  • 优势
    • 独立性
    • 敏捷性
    • 技术栈灵活
    • 高效团队
  • 不足
    • 额外的工作(DDD【Domain-Driven Design 领域驱动设计】可以做微服务拆分的学习)
    • 数据一致性
    • 沟通成本

微服务如何拆分


微服务拆分的起点

  • 起点

    • 既有架构的形态
  • 终点

    • 好的架构不是设计出来的,而是进化出来的
    • 一直在演进ing

适合上微服务么?

  • 业务形态不适合的
    • 系统中包含很多很多强事务场景的
    • 业务相对稳定,迭代周期长
    • 访问压力不大,可用性要求不高
    • ...

康威定律和微服务

  • 传统和微服务


    传统和微服务

  • 康威定律

    • 任何组织在设计一套系统(广义概念上的系统)时,所交付的设计方案在结构上都与该组织的沟通结构保持一致
    • 沟通的问题会影响系统的设计

    所以,上不上微服务已经不是使用某个技术栈的技术问题了,已经上升到一个团队结构有关的管理问题了


服务拆分的方法论


扩展立方模型(Scale Cube)

image

X轴 水平复制
  • 通过将应用程序水平复制,通过负载均衡运行多个完全一样的副本,来实现应用程序的伸缩性,提高应用程序的容量和可用度
Z轴 数据分区
  • 每个服务器负责的一个数据子集,每个服务器运行的代码是一样的
Y轴 功能解耦
  • 将不同职等的模块分成不同的服务

如何拆“功能”

  • 单一职责,松耦合、高内聚
  • 关注点分离
    • 按职责
    • 按通用性
    • 按粒度级别

服务和数据的关系

  • 先考虑业务功能,再考虑数据
  • 无状态服务
    image

如何拆"数据"

  • 每个微服务都有单独的数据存储
  • 依据服务特点选择不同结构的数据库类型
  • 难点在于确定边界
    • 针对边界设计API
    • 依据边界权衡数据冗余

微服务核心组件


微服务带来的问题

  • 微服务间如何发现彼此
  • 服务间如何通讯
  • 微服务容错处理
  • 微服务的配置问题

SpringCloud核心组件

  • Eureka(注册中心)
  • Ribbon(负载均衡)
  • Hystrix(断路器)
  • Zuul(服务网关)
  • Config(配置中心)

Eureka(注册中心)

  • 在分布式系统里,必须要有一个角色对所有微服务的状态、地址、及实例数进行集中管理和收集,并能定期的监控所有微服务的状态,这就是Eureka,能提供服务注册和注册中心功能


    image

  • 两个组件组成
    • Eureka Server 注册中心
    • Eureka Client 服务注册
      • 服务端发现和客户端发现
        image

Ribbon(负载均衡)

  • Ribbon是SpringCloudNetfilix微服务套件中的一部分,提供负责均衡、容错、异步和多协议(HTTP,TCP,UDP)支持、缓存、批处理功能 .


    image

Hystrix(断路器)

  • 在一个分布式系统里,许多依赖不可避免的会调用失败,比如超时、异常等,如何能够保证在一个依赖出问题的情况下,不会导致整体服务失败,这个就是Hystrix需要做的事情。Hystrix提供了熔断、隔离、Fallback、cache、监控等功能,能够在一个、或多个依赖同时出现问题时保证系统依然可用。

image

  • 熔断
    • 当Hystrix Command请求后端服务失败数量超过一定比例(默认50%), 断路器会切换到开路状态(Open). 这时所有请求会直接失败而不会发送到后端服务.

  • 断路器保持在开路状态一段时间后(默认5秒), 自动切换到半开路状态(HALF-OPEN). 这时会判断下一次请求的返回情况,如果请求成功, 断路器切回闭路状态(CLOSED), 否则重新切换到开路状态(OPEN).

  • Hystrix的断路器就像我们家庭电路中的保险丝, 一旦后端服务不可用, 断路器会直接切断请求链, 避免发送大量无效请求影响系统吞吐量, 并且断路器有自我检测并恢复的能力.

  • 隔离
    • 在Hystrix中, 主要通过线程池来实现资源隔离. 通常在使用的时候我们会根据调用的远程服务划分出多个线程池.
      • image

  • Fallback
    • Fallback相当于是降级操作. 对于查询操作, 我们可以实现一个fallback方法, 当请求后端服务出现异常的时候, 可以使用fallback方法返回的值. fallback方法的返回值一般是设置的默认值或者来自缓存.告知后面的请求服务不可用了,不要再来了。

  • cahce
    • 比如一个请求过来请求我userId=1的数据,你后面的请求也过来请求同样的数据,这时我不会继续走原来的那条请求链路了,而是把第一次请求缓存过了,把第一次的请求结果返回给后面的请求。

  • 监控
    • HyStrix自身提供了监控系统,可以对接口状态进行监控,但是实时性的,没有持久化存储,我们后期是可以用第三方系统监控数据的采集与报警

Zuul(服务网关)

  • API网关可以提供一个单独且统一的API入口用于访问内部一个或多个API。简单来说嘛就是一个统一入口,比如现在的支付宝或者微信的相关api服务一样,都有一个统一的api地址,统一的请求参数,统一的鉴权。

服务网关

服务网关


  • Zuul的核心一系列的过滤器:
    • 身份认证与安全:识别每个资源的验证要求,并拒绝那些与要求不符的请求。
    • 审查与监控:在边缘位置追踪有意义的数据和统计结果,从而带来精确的生产视图。
    • 动态路由:动态地将请求路由到不同的后端集群。
    • 压力测试:逐渐增加指向集群的流量,以了解性能。
    • 负载分配:为每一种负载类型分配对应容量,并启用超出限定值的请求。
    • 静态响应处理:在边缘位置直接建立部分相应,从而避免其转发到内部集群。

Config(配置中心)

  • 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件。
    • 核心功能
    • 提供服务端和客户端支持
    • 集中管理各环境的配置文件
    • 配置文件修改之后,可以快速的生效
    • 可以进行版本管理
    • 支持大的并发查询
    • 支持各种语言

image
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容