微服务架构设计模式 | 第1章 逃离单体地狱

前言

这是一本关于微服务架构设计方面的书,这是本人阅读的学习笔记。首先对一些符号做些说明:

()为补充,一般是书本里的内容;
[]符号为笔者笔注;


1. 迈向单体地狱的漫长旅程

在书中,作者以Food to Go(下简称FTGO)业务分析单体应用程序的优缺点。

1.1 FTGO应用程序单体架构

FTGO单体

1.2 单体架构的好处

  • 应用开发简单;
  • 易对应用程序进行大规模修改;
  • 测试相对简单直观;
  • 部署简单明了;
  • 横向扩展不费吹灰之力;

1.3 FTGO应用程序单体地狱

FTGO单体地狱

1.4 什么是单体地狱

  • 过度复杂性会吓退开发者;
  • 开发速度慢;
  • 从代码提交到实际部署的周期很长,容易出问题;
  • 难以扩展;
  • 交付可靠的单体应用是一项挑战;
  • 需要长期依赖某个可能已过时的技术栈;


2. 为什么本书与你有关

什么人适合阅读:软件开发人员、架构师、CTO或工程研发副总裁;或者所负责的应用程序超出单体架构所能支撑的范围。

2.1 阅读门槛

  • 三层架构;
  • Web应用程序设计;
  • 使用面向对象设计来开发业务逻辑;
  • 关系型数据库:SQL和ACID事务的概念;
  • 使用消息代理和REST API进行进程间通信;
  • 安全,包括身份验证和访问授权;
  • Spring框架;


3. 你会在本书中学到什么

读完本书能理解与掌握的知识点与技术点。

3.1 需要重点关注的知识

  • 微服务架构的基本特点,它的好处与弊端,以及在什么时候使用微服务架构;
  • 分布式数据管理的架构模式;
  • 针对微服务架构应用程序的有效测试策略;
  • 微服务架构应用程序的部署方式;
  • 把单体应用重构为微服务架构的策略;

3.2 其他技术

  • 使用微服务的架构模式来设计应用程序的架构;
  • 为服务开发业务逻辑;
  • 使用Saga在进程间维护数据的一致性;
  • 实现跨服务的数据查询;
  • 更高效地测试服务架构应用程序;
  • 开发生产环境就绪的应用程序,实现安全性、可配置性和可观测性;
  • 把现有的单体应用重构为服务;


4. 拯救之道:微服务架构

主要介绍人微服务架构的一些定义与基本特性。

4.1 扩展应用程序的三个维度(扩展立方体)[微服务的定义]

扩展立方模型
  • X轴扩展:在多个实例之间实现请求的负载均衡,[简单来说就是Ctrl CV];
  • Z轴扩展:根据请求的属性路由请求,(用于应用程序需要处理增加的事务和数据量时),[流量分区扩容];
  • Y轴扩展:根据功能把应用拆分为服务,(亦称为功能性分解),[一般先进行Y轴扩展,再采用X、Z轴扩展];

4.2 微服务的基本特性

  • 扩展立方体;
  • 模块化,[指开发人员无法绕开服务的API访问内部组件];
  • 每个服务拥有自己的数据库;

4.3 FTGO的微服务架构

将Y轴分解应用于FTGO应用程序,将得到下图:

FTGO的微服务架构

可以看出该模型的特点有:

  • 每个服务API清晰定义;
  • 每个服务可以独立开发、测试、部署和扩展;
  • 模块化;

4.4 微服务架构与SOA的异同

微服务架构与SOA的异同

相似点:

  • 都是特定的风格架构;
  • 都以一系列服务方式组织系统;

不同点:

  • 完全不同的技术栈(微服务架构采用轻量级、开源技术以及哑管道通信);
  • 处理数据方式不同(微服务架构有自己的数据库);
  • 服务尺寸、规模不同(微服务架构中的服务相对较小);


5. 微服务架构的好处与弊端

5.1 微服务架构的好处

  • 使大型的复杂应用程序可以持续交付和持续部署,[支持自动化测试、独立部署、开发团队自主且松散耦合];
  • 每个服务都相对较小并容易维护;
  • 服务可以独立部署;
  • 服务可以独立扩展;
  • 微服务架构可以实现团队的自治;
  • 更容易实验和采纳新技术;
  • 更好的容错性;

5.2 微服务架构的弊端

  • 服务的拆分与定义是一项挑战;
  • 分布式系统带来各种复杂性,使开发、测试和部署变得困难;
  • 当部署跨越多个服务的功能时需要谨慎地协调更多开发团队;
  • 开发者需要思考到底应该在应用的什么阶段使用微服务架构;


6. 微服务架构的模式语言

一个用来表述多种架构设计的选择方案,并且可用来改进决策的方式,就是使用模式语言。微服务架构的模式是微服务架构设计的重难点,也是后续章节的重难点。

6.1 一些概念(模式、模式语言等)

  • 模式:针对特定上下文中发生的问题的可重用解决方案;
  • 模式语言:解决特定领域内问题的相关模式的集合;
  • 软件模式:通过定义一组互相协作的软件元素来解决软件架构或设计问题;

6.2 常用的模式结构包括三个重要部分

  • 需求(Forces):必须解决的问题;
  • 结果上下文(Resulting context):采用模式后可能带来的后果(包含好处、弊端、问题);
  • 相关模式(Related patterns):5种不同类型的关系(前导、后续、替代、泛化、特化);
以可视化方式表示模式间的关系

6.3 微服务架构模式语言

微服务架构模式语言的概括性视图

上图有四个模式组

  • 应用程序架构模式组:最左边,分为单体架构模式与微服务架构模式;
  • 应用相关模式组:解决开发人员面对的具体技术和架构问题;
  • 应用基础设施相关模式组:解决应用层面的基础设施相关问题;
  • 基础设施相关模式组:解决通常在开发环节跟基础设施有关的问题;

6.4 微服务的主要几组模式【重点】

服务拆分相关模式:

【第2章重点介绍】将系统拆分本质上是一门艺术,但可以有一定策略,如下图所示:

服务拆分相关策略

通信相关模式:

【第3与第8章介绍】进程间通信(IPC)是分布式系统的重要组成部分,其包括:

  • 通信风格:使用哪类进程间通信机制;
  • 服务发现:客户端如何获取服务具体实例的IP地址;
  • 可靠性:在服务不可用情况下,如何确保服务间的可靠通信;
  • 事务性消息:如何将消息发送、事件发布这样的动作与更新的业务数据的数据库事务集成;
  • 外部API:应用程序的客户端如何与服务进行通信;

实现事务管理的数据一致性相关模式:

【第4~6章介绍】使用Saga模式确保数据一致性,而不是两步式提交(2PC)方式。下图展示数据一致性相关模式:

数据一致性相关模式

在微服务架构中查询数据的相关模式:

【第7章介绍】可以使用API组合模式,逐一调用服务的API,然后将所有的返回聚合在一起,如下图所示:

查询数据的相关模式

服务部署相关模式:

【第12章介绍】往往需要一个高度自动化部署的基础设施,一个部署平台(可以是UI图形化界面、命令行等),如下图所示:

请部署微服务的几种模式

可观测性相关模式:

【第11章介绍】指弄清应用在运行时的一些行为,同时根据错误的请求或高延迟等故障进行诊断排错。以下模式可用来设计具备可观测性的服务:

  • 健康检查API:可以返回服务健康状态的API;
  • 日志聚合:把服务产生的日志写入一个集中式的日志服务器,这个服务器可以提供日志搜索,也可以根据日志情况触发报警;
  • 分布式追踪:为每一个外部请求分配一个唯一的ID,用于在各个服务之间追踪外部请求;
  • 异常跟踪:把程序异常发送到异常跟踪服务,这个服务会排除重复异常,给开发者发送报警并且跟踪每一个异常的解决;
  • 应用指标:供维护使用的指标,如计数器等,导出到指标服务器;
  • 审计日志:记录用户的行为;

实现服务自动化测试的相关模式:

【第9~10章介绍】需要注意测试不同服务是否协同工作。以下通过单独测试服务简化测试的模式:

  • 消费者端驱动的契约测试:验证服务满足客户端所期望的功能;
  • 消费端契约测试:验证服务的客户端可以正常与服务通信;
  • 服务组件测试:在隔离的环境中测试服务;

解决基础设施和边界问题的相关模式:

【第11章介绍】每个服务都必须实现许多跟基础设施相关的功能,此外必须实现外部化配置模式。在开发新服务时可以使用微服务基底模式解决一些基础设施的相关问题。

安全相关模式:

【第11章介绍】在用户身份验证工作中常用访问令牌模式,用户信息传递后的服务可以验证令牌获取用户信息。


7. 微服务之上:流程和组织

架构不是唯一需要关注的领域,还必须思考流程与组织。

7.1 架构、流程与组织间的关系

请添加图片描述


8. 本章小结

  • 单体架构模式将应用程序构建为单个可部署单元;
  • 微服务架构模式将系统分解为一组可独立部署的服务,每个服务都有自己的数据库;
  • 单体架构是简单应用的不错选择,微服务架构通常是大型复杂应用的更好选择;
  • 微服务架构使小型自治团队能够并行工作,从而加快软件开发的速度;
  • 微服务架构不是银弹:它存在包括复杂性在内的诸多弊端;
  • 微服务架构模式语言是一组模式,可帮助你使用微服务架构构建应用程序。它可以帮助你决定是否使用微服务架构,如果你选择微服务架构,模式语言可以帮助你有效地应用它;
  • 你需要的不仅仅是通过微服务架构来加速软件交付。成功的软件开发还需要DevOps和小而自治的团队;
  • 不要忘记采纳微服务过程中的人性层面。你需要考虑员工的情绪才能成功转换到微服务架构。



最后

\color{blue}{\rm\small{新人制作,如有错误,欢迎指出,感激不尽!}}

\color{blue}{\rm\small{欢迎关注我,并与我交流!}}

\color{blue}{\rm\small{如需转载,请标注出处!}}

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

推荐阅读更多精彩内容