我对微服务的理解

目前公司Java团队使用SpringCloud(SC)搭建后台微服务架构,由于SC比较新,团队也是处于摸索阶段,边挖掘边踩坑,大致的架构已经初步形成,本文主要谈下我对微服务以及微服务框架SpringCloud的理解。

什么是单体应用

定义微服务前首要要定义单体应用。所谓单体应用是指所有的模块、业务都包含在一个应用中,比如用户管理模块、内容管理模块、推送模块全部放在一个应用中,发布时打成一个独立的包,放到Web容器中。

单体应用的优势是它部署起来非常方便,如果规模不大的话,开发测试也比较方便。

它的劣势也很明显:

  1. 复杂度高导致可维护性低: 随着需求的增加,项目规模开始膨胀,对象间的依赖关系变得复杂,编译以及测试度秒如年,调试起来也不再轻松,你喜欢的IDE也会变得越来越卡,随着时间的推移和人员的更迭,不同的代码风格交织在一起,可维护性变得越来越低。
  2. 发布频率低导致发布风险高: 虽然单体应用易于部署,但因为每次发布都需要重新部署整个应用,中断所有服务,为了减少中断的时间不得不降低发布频率,因此两次发布之间可能有大量的变更,导致发布风险比较高。
  3. 可靠性差: 所有模块共享一个进程,某个模块的bug可能导致整个应用瘫痪。
  4. 扩展灵活度低: 无法根据不同的业务需求选择不同的硬件规格进行部署,比如IO密集型的模块需要更大的内存,计算密集型的模块需要更快的CPU。
  5. 技术栈受限: 单体应用的语言、框架通常是统一的,如果希望不同模块用不同的语言、框架做是比较困难的,比如用户模块用Java,推送模块用Go。

什么是微服务

微服务和单体应用恰恰相反,把各个模块拆分成不同的项目,每个模块都只关注一个特定的业务功能,发布时每一个项目都是一个独立的包,运行在独立的进程上。微服务应该足够小,小到即使全部重写也不需要过多的时间。微服务化是SOA(Service-Oriented Architecture,面向服务的架构)的一种方法。

它解决了单体应用造成的一些问题:

  1. 易于开发,可维护性高: 一个服务只会关注一个特定的业务模块,代码比较少,可维护性就高。
  2. 发布风险低: 发布单个服务不需要重新发布整个应用。
  3. 技术栈不受限(异构): 微服务之间通过轻量级的通信机制进行通信,比如RESTful API,因此不同项目可以随意选择合适的技术来实现。
  4. 按需伸缩: 可以针对特定的服务,结合业务特点分配不同的硬件规格。

当然,微服务不是完美的,在解决一旧问题的同时带来了新的问题:

  1. 运维要求高: 对于单体应用只要部署一个服务,微服务化后可能需要部署几十几百个服务.
  2. 分布式固有的复杂性: 开发人员需要考虑分布式事务、系统的容错性等,比如服务A的某个接口依赖服务B,通过RESTful API调用服务B的接口但发生了错误,需要提供重试等机制。
  3. 修改接口成本增加: 修改接口本就是一件繁琐的事,微服务化后成本更高,因为各个服务之间只通过轻量级通信机制访问,耦合度比较低,需要排查哪些服务的接口受到了影响,而在单体应用中通常只是方法间的依赖,如果修改了某个方法的签名,那么在编译时就会报错。
  4. 重复劳动: 当一个单体应用微服务化后,不同的服务之间会有重复代码产生,比如Gradle脚本、Maven依赖都非常类似,使用到的某些函数每个服务都造了一遍等,如果都是用同一种语言实现的还能用共享库解决,如果有多种语言那就难以避免重复劳动了。

微服务设计原则

  1. 单一职责原则: 每个服务应该只关注特定的某一类业务。
  2. 服务自治原则: 每个服务具备独立的业务能力、依赖和运行环境,与其他服务高度解耦,每个服务都应当可以独立运行,不应该依赖其他服务。
  3. 轻量级通信机制: 应该使用轻量级的、语言无关的、跨平台的协议,如REST、MQTT等。

什么样的服务是好服务

  1. 松耦合
    如果修改一个服务的同时不需要修改另一个服务,那么就做到了松耦合。一个紧耦合的例子是,两个服务依赖了同一个持久化对象,如果其中一个服务要修改该持久化对象,那么另一个服务也很有可能需要修改,从而导致紧耦合。另外对于某些RPC(如Java RMI)而言,返回值对象的修改也可能引起该服务提供者的调用方服务的修改,否则可能导致某些序列化错误的问题。
  2. 高内聚
    相关的行为应该聚集在一起,不相关的行为放在别处。一个低内聚的例子是,每种不同的服务都有自己关于推送功能的代码,那么一旦推送代码出现了问题,所有涉及到的服务都要修改。对于一种行为,最好只在一个地方修改。

参考:
1. 电子工业出版社 -《Spring Cloud与Docker微服务架构实战》
2. 人民邮电出版社 -《微服务设计》

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

推荐阅读更多精彩内容