微服务架构设计实践

微服务架构设计实践

1 序言

最近,在软件架构设计领域,微服务非?;?。

一提到软件开发、架构设计,如果不提微服务,不说说微服务的架构风格,那就落伍了,OUT了。

当然了,支持微服务的技术也是层出不穷,如微服务1.0中比较有名的来自Spring家族的Spring Cloud,以及国内在开源领域的翘楚阿里系中的Dubbo。其中,Spring Cloud提供了完整的微服务解决方案,为开发者提供了快速构建分布式系统的通用模型的工具,包括配置管理、服务发现、熔断器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话、集群状态等。而Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及服务治理方案。

随着微服务的持续火热,微服务2.0中的ServiceMesh也火起来了。Service Mesh,即“服务网格”,作为服务间通信的基础设施层,Service Mesh可以被看作是微服务间的TCP/IP,负责服务之间的网络调用、限流、熔断和监控。对于编写服务的开发人员来说,一般无须关心TCP/IP这一层(比如通过 HTTP 协议的 RESTful 应用),同样使用Service Mesh也就无须关心服务之间的那些原来是通过应用程序或者其他框架实现的事情,比如Spring Cloud、OSS,现在只要交给Service Mesh就可以了。

其实,上述说了那么多,介绍了那么多,基本都是集中在概念层面,在理论的层次上,以及支持微服务的开发技术、开发框架上,缺少这些概念、理论、技术和框架在实际项目中具体地应用。

对于大多数开发人员、架构师来说,除了理解微服务相关的概念,熟悉微服务相关的技术和框架,更关心如何在实际的项目中,应用这些概念、技术和框架。而这些,正是现在所欠缺的。

笔者从事软件开发多年,参与和指导过多个项目的架构设计,经历过单体架构、分布式架构、SOA架构,对软件架构的发展历史有一定的了解。

同时,在架构设计过程中,笔者也拜读了多位架构大师的著作,如温昱老师的《软件架构设计》、《一级架构师》,Peter Eeles和Peter Cripps的《软件架构设计的过程》等,以及各位技术大咖们在互联网上分享的各类架构相关的文档,使我受益匪浅。在此,我衷心的对这些前辈们表示由衷的感谢,谢谢你们对于知识的分享,以及无私奉献的精神。

最近,笔者有幸参与了某银行的一个采用微服务架构风格的项目,实践了一下微服务架构。

更确切地说,该项目是分布式服务架构向微服务架构的演进,使用更细粒度的服务和一组设计准则来考虑大规模的、复杂的系统架构设计,并非一个纯粹的微服务架构风格的项目。

秉着知识共享的精神,笔者写了这篇“微服务架构设计实践”的文章,一方面是对自己在架构设计方面的一个阶段性总结,另一方面是希望给其他刚刚从事软件架构设计的人员一个真实的、具体的软件架构过程的实践参考,为他们提供一个完整的实践案例。

在写这篇文章的过程中,在介绍微服务、软件架构设计思想的概念、方法论时,引用了各位大师、技术大咖们关于微服务、架构设计的文章中的内容,在此衷心地表示感谢。对于引用的内容,笔者并非简单地摘抄,而是结合笔者的理解和实践,做了适当的调整。如果存在不适、错误的地方,希望各位及时地指出,我将积极的采纳和修改。

2 微服务

2.1 微服务的定义

微服务是一个独立、可部署的服务,它只专注做一件事情并且做好,而这个事情通??梢允且滴衲芰?,或者提供业务价值的最小单元服务。

微服务的描述具有一般服务描述所遵循的内容:

1.使用明确的接口方式,如:WebService、Rest。

2.描述里应该包括约束和策略,如:参数、返回值,以及使用什么通讯协议和数据格式等。

微服务中“微”是其独特个性的体现,“微”表示“接口粒度细”。

简而言之,微服务的特征归结为:

1.职责单一,相对独立。

2.接口粒度细。

3.轻量级通讯协议。

4.服务之间松耦合。

2.2 微服务架构的定义

James Lewis 和 Martin Fowler 给微服务架构的定义如下:

微服务架构风格指将复杂系统切分为几十甚至上百个小服务,每个服务负责实现一个独立的业务逻辑。系统中的各个服务通常是独立部署,彼此之间是松耦合的。

每个服务都运行在自己的进程中,一般采用Rest API风格的轻量级通讯协议进行相互通信。

这些服务围绕业务功能进行构建,通过全自动化的部署方式来进行独立部署。

这些服务可以使用不同的语言来编写,也可以使用不同的数据存储技术,并且基于最低限度的集中管理。

2.3 微服务架构的特征

Martin Fowler 认为,微服务架构具有如下 9 个特性:

1.组件以服务的形式提供。

2.围绕业务功能进行组织。

3.产品而不是项目。

4.强化终端与弱化管道。

5.“去中心化” 地治理技术。

6.“去中心化” 地管理数据。

7.“基础设施” 自动化。

8.“容错” 设计。

9.“演进式” 设计。

2.4 微服务架构的优缺点

微服务架构的优点在于:

1.更加彻底的组件化,系统内部各个组件之间解耦的比较干脆,单个系统的规模小很多。

2.可以组建每个服务独立的维护团队,利于各自团队独立的开发和维护。

3.每个微服务独立部署,只要服务间的接口稳定,各系统可以相互之间互不干扰的独立发展。

4.微服务架构使得每个服务本身可以独立的扩展,性能出现瓶颈,优化或增加这个服务的配置即可。

微服务架构的缺点在于:

1.微服务强调了服务大小,但实际上,业界并没有给出一个明确的、统一的标准。业务逻辑应该按照什么规则划分为微服务,这本身就是一个经验工程。但要记住,微服务是达到目的的手段,而不是目标。微服务的目标是充分分解应用程序,以促进敏捷开发和持续集成部署。

2.它的分布式特点带来的复杂性??⑷嗽毙枰赗PC或者消息实现微服务之间的调用和通信,而这就使得服务之间的发现、服务调用链的跟踪和质量问题变得的相当棘手。

微服务架构所面临的挑战:

1.分区的数据库体系和分布式事务。在微服务架构下,不同服务可能拥有不同的数据库。CAP原理的约束,使得我们不得不放弃传统的强一致性,而转而追求最终一致性,这个对开发人员来说是一个挑战。

2.对测试带来了很大的挑战。对微服务进行测试,需要启动它依赖的所有其他服务,这种复杂性不可低估。

3.对跨多个服务的更改带来的挑战。在微服务架构中,若有A、B、C三个服务需要更改,A依赖B,B依赖C。此时,我们需要仔细规划和协调每个服务的变更部署,可能需要先更新C,然后更新B,最后更新A。

4.部署基于微服务的应用也要复杂得多。微服务由不同的大量服务构成,每种服务拥有自己的配置、应用实例数量以及基础服务地址,这里就需要不同的配置、部署、扩展和监控组件。此外,我们还需要服务发现机制,以便服务可以发现与其通信的其他服务的地址。因此,成功部署微服务应用需要开发人员有更好地部署策略和高度自动化的水平。

基于上述的微服务存在的优缺点,以及微服务架构设计过程中面临的挑战,建议在软件架构设计时,不要从一开始就以微服务架构作为系统设计的起点。相反地,要用一个单个系统作为起点,并保持其模块化。当这个系统出现了问题后,再将其分解为微服务。

3 软件架构设计思想

3.1 软件架构定义

对于软件架构的定义,仁者见仁,智者见智。目前,业界比较流行的两大流派是组成派和决策派,这两派的概念相辅相成,具体如下:

组成派:软件架构 = 组件 + 交互。

决策派:软件架构 = 重要决策集。

上述两大流派的描述过于抽象,不利于理解,本人更喜欢下述关于软件架构的描述,通俗易懂,即:

软件架构是软件整体结构与组件的抽象描述,用于指导大型软件系统各个方面的设计。软件架构描述的对象是直接构成系统的抽象组件,各个组件之间的连接则明确和相对细致地描述组件之间的通讯。在实现阶段,这些抽象组件被细化为实际的组件,比如具体某个类或者对象。在面向对象领域中,组件之间的连接通常用接口来实现。

软件架构是一个用于指导系统实现的草图,这个草图越详细对于系统实现的指导意义越重大,贯穿于软件的整个生命周期。

3.2 软件架构本质

架构的本质就是对系统进行有序化重构,不断减少系统无序的程度,使系统不断进化。

架构从无序到有序的基本实现手段是分和合,即先把系统打散,然后重新组合。

分的过程是把系统拆分为各个子系统、??椤⒆榧?。拆分的时候,首先要解决每个组件的定位问题,然后才能划分彼此的边界,实现合理的拆分。合的过程就是根据最终要求,把各个分离的组件有机整合在一起。

分的结果使开发人员能够做到业务聚焦、技能聚焦,实现开发敏捷;

合的结果使系统变得柔性,可以因需而变,实现业务敏捷。

相对来说,第一步的拆分更难。

3.3 软件架构过程

在此次软件架构设计过程中,采用了温昱老师在《软件架构设计》一书中提及的ADMEMS方法体系。

ADMEMS方法通过3个阶段和一个贯穿环节,来覆盖“需求进,架构出”的完整架构设计过程。

3.3.1 PA阶段

架构准备阶段是架构设计的第一个阶段,此阶段的工作目标是:理解需求,建立需求大局观,确定架构设计方向等。

功能需求、质量属性和约束共同决定了架构,对这3类需求的把握是否到位、设计决策是否对路,是软件架构设计的关键所在。

如果可能的话,架构师应该尽早的参与需求分析工作,对需求进行大局的梳理,而不能被动地等待《软件需求规格说明书》的完成。

只要满足以下3个条件,架构师就可以开始架构设计工作:

1.明确的业务需求:甲、乙双方对系统的目标达成共识,《愿景文档》通过了正式评审,并且明确了投资、工期标准、整合等约束条件。

2.全面的用户需求:系统范围明确,即系统能帮用户干什么,不能干什么。

3.典型的行为需求:核心功能的《用例规约》已定义。

在架构准备阶段,通过对软件需求的详细分析,抽取出确定概念性架构所需要的关键需求。

此阶段的输入是软件需求(即上述的三部分:明确的业务需求、全面的用户需求、典型的行为需求),成果物是确定的关键需求,包括关键功能、关键质量属性和关键约束影响,作为下一个阶段的输入。

3.3.2 CA阶段

概念架构是对系统设计的最初构想,对大型系统的成功非常关键。

概念性架构定义了系统的高层组件,笼统地界定了高层组件的职责,以及它们之间的关系。

概念性架构主要是对系统进行适当的分解,而不陷入细节。

概念性架构规定了每个组件的非正式规约及架构图,但不涉及接口细节。

在进行概念架构设计时,必须牢牢抓住重大需求、特色需求、高风险需求,有针对性地确定解决方案。

关键需求塑造概念架构。反过来,概念架构体现关键需求。

此阶段的输入是关键需求,包括关键功能、关键质量属性和关键约束影响,成果物是针对关键问题的解决策略,和以高层抽象组件方式描述的整个系统的组成草图,可以用在《软件方案建议书》。此成果物作为下一个阶段的输入。

3.3.3 RA阶段

从概念架构到细化架构,先设计概念架构,构思关键问题的解决策略;再进行细化架构的设计,以保证为开发提供足够的指导和限制。

在细化架构阶段,整体设计思路为以分而治之为核心思想的多视图方法。

此阶段的输入是关键问题的解决策略,和以高层抽象组件方式描述的整个系统的组成草图,成果物是描述系统的各种视图,这些视图从不同的角度,不同的关注点,描述了抽象的、完整的系统解决方案。

3.4 软件架构视图

多视图方法是业界广泛认可的一种架构设计思路。

一种优秀的多视图方法,应该能够比较完善地覆盖架构设计的各项工作内容,并且将每项工作内容明确地、有理有据地、一目了然地划归到不同的架构视图中去。

在多视图方法中,每个视图都从一个思维角度聚焦一组技术关注点,都从特定角度规划系统的拆分和组合,都是架构的一种体现。

多视图方法种类繁多,其中影响最大的当属由Philippe Kruchten于1995年首次提出的RUP的4+1视图方法,涉及视图分别为逻辑架构视图、运行架构视图、开发架构视图、数据架构视图、物理架构视图。

另一种在架构设计中经常使用的多视图方法是联邦企业架构框架(Federal Enterprise Architecture Framework),涉及视图分别为:业务架构视图、数据架构视图、应用架构视图、技术架构视图。

本人所使用的视图方法是以RUP的4+1视图方法和联邦企业架构框架为基础,基于本人在架构设计方面的实践经验,总结出常用的6中架构视图,涉及视图为:业务架构视图、数据架构视图、应用架构视图、技术架构视图、物理架构视图、开发架构视图。

为了理论与实践相结合,对于每种视图的介绍放到架构设计实践的细化架构阶段,结合实际的项目,详细描述每种视图。

3.5 架构之间的关系

从根本上讲,架构设计毫无疑问是需求驱动的。所以,软件需求是整个软件架构设计过程的前提条件。

在架构设计过程中,不同的架构视图之间并不是孤立存在的,它们之间存在着依赖关系,并且这些依赖关系也决定了这些架构视图的设计顺序,具体如下:

1.第一步,根据用户需求确定业务架构。

2.第二步,根据业务架构,分析、定义数据架构。

3.第三步,根据数据架构,并结合功能需求定义应用架构。

4.第四步,根据数据架构与应用架构来设计技术架构。

5.第五步,根据数据架构、应用架构和技术架构,来设计开发架构。

4 微服务架构设计实践

4.1 项目概述

为了支持分行特色业务在某银行科技总体架构下高效、规范实施,总行构建了分行特色业务云平台,旨在为分行应用提供全面、易用、统一、安全可靠的服务能力,包括业务能力和技术能力,降低对于总行产品??榈慕尤肽讯龋蹇刂平尤敕缦?,同时整合、集成总行服务能力。

分行特色业务云平台是一套以总分协同、共享服务体系架构的分行特色业务开发平台。该平台基于行方自主研发的Tesla基础技术框架,实现全分行统一、规范技术支撑架构,为分行应用提供全面、易用、安全可靠的服务。以此为基石,更深、更广泛的发挥全分行科技人员开发能力和对业务支持响应能力。

此次设计的分行特色业务云平台以Tesla平台作为技术载体,采用分布式服务框架理论作为设计依据,在此基础上,构建JAVA版特色业务分平台(JCAP-Java Cloud Application Platform)、服务融合中心(SCC-Service Convergence Center)。

服务融合中心在本次分行特色业务平台的定位是对分行特色业务提供各种总行后台模块的服务能力,并且对分行特色业务的接入做到统一管理和差异化控制功能。

end

顺便在此给大家推荐一个Java方面的交流学习群:957734884,里面会分享一些高级面试题,还有资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系,主要针对Java开发人员提升自己,突破瓶颈,相信你来学习,会有提升和收获。在这个群里会有你需要的内容 朋友们请抓紧时间加入进来吧

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

推荐阅读更多精彩内容

  • 微服务架构设计实践 目 次 1 序言 2 微服务 3 软件架构设计思想 4 微服务架构设计实践 4.1 项目概述 ...
    高级java架构师阅读 3,332评论 1 14
  • 我一个人抱着手机想写些什么,却又只能对着屏幕发呆,或者是不断地敲击着退格键。生活节奏太快了,谁会理会你的故事。
    真小奕阅读 103评论 0 0
  • 2017年下半年以来国家出重拳治理污染,对污染型的企业产生了一定的负面影响,然后投资儿童室内水上乐园的却是一个既节...
    恒温水上乐园阅读 123评论 0 0
  • 他们说 你眼里有星辰大海 一曲作罢 博得满堂彩 你身着一身长衫站在胡同口 遮一层嫩柳 掩一层清风 哼着小曲儿的少年...
    泠酒鲤阅读 156评论 0 1