单体架构和微服务系统架构的优缺点

烟囱式系统建设的弊端:

1.重复功能的建设和维护带来的重复投资

2.烟囱式系统交互集成和协作成本高

3.不利于业务的沉淀和持续发展


 

1.重复功能的建设和维护带来的重复投资

这一条很好理解就是当我们公司内部拥有多套子系统的时候,势必会带来一些重复性的工作,比如说公司内部OA系统和报表系统、两个系统按照单独的设计都会存在用户管理功能,如果某一天公司需要在加一套管理系统的话,那么在管理系统中还需要添加一套用户管理的逻辑,该重复功能的建设工作和维护势必会带来时间、资源上的浪费。

 

2.烟囱式系统交互集成和协作成本高

随着公司内部系统业务不断的增加以及完善,多个系统之间的集成和交互也将变得困难,多系统之间的协作、沟通成本较高,例如公司有一套mes系统(生产制造系统)该系统当中有wip模块、alm模块当有一天我新建了一个报表系统去统计使用人数,那我需要从两个系统当中分别去获取用户,带来的时间成本和沟通成本是比较高昂的

3.不利于业务的沉淀和持续发展

不利于产品的快速跟新和迭代,当今互联网项目每周每月都在不停的变化、市场的反馈根业务上的需要都需要得到快速的响应,而传统系统的迭代周期长对业务响应不及时。

为什么要微服务化

1.协作成本高,业务响应慢 

传统单体架构如果功能模块100个以上一般的公司内部按照功能模块进行划分工作,每一次新版本上线总会出现各种问题,例如分支合并冲突、代码不一致、等各种问题也会带来很大的协作成本,沟通成本。

2.系统复杂度增加难以维护

单体架构随着业务量不断的增加和扩展以及随着组织人员的变化,业务代码也会变得越来越难以维护,一次小小的改动可能会带来灾难行的风险!

3.错误不能隔离

当所有的业务功能模块都聚集在一个程序集当中,如果其中的某一个小的功能模块出现问题,那么都有可能会造成整个系统的崩溃

4.数据库连接能力很难扩展

数据库集群的连接数量是有限的,当数据库的连接数量资源随着实例的增加将难以保证

5.应用扩展能力差

单体架构不能够按需扩展,例如某一天我们的网站当中部分业务模块访问量暴增,如果我们要对服务扩展只能把整个系统进行打包、发布而不能针对特定的模块进行扩容


综合上述烟囱式建设模式带来的一些弊端接下来讲到了soa方法,SOA的主要特点有如下几种:

面向服务的分布式计算

服务间松耦合

支持服务的组装

服务注册和自动发现

以服务契约方式定义服务交互方式


SOA架构带来的真正核心意义价值:服务重用。


单体架构

所谓的单体架构就是把所有的业务模块编写在一个项目中,最终会打包成一个war包,然后进行部署

单体架构的优点:

部署简单:由于是完整的结构体,可以直接部署在一份服务器上即可

技术单一:项目不需要复杂的技术栈,往往一套熟悉的技术栈就可以完成开发

用人成本低:单个程序员可以完成业务接口道数据库的整个流程

单体架构的缺点:

系统启动慢:一个进程包含了所有的业务逻辑,涉及到的启动模块过多,导致系统的启动时间周期过长

系统错误隔离性差:可用性差,任何一个模块的错误均可能造成整个系统的宕机

可伸缩性差:系统的扩容只能对这个应用进行扩容,不能做到对莫讴歌功能点进行扩容

线上问题修复周期长:任何一个线上问题修复需要对整个应用系统全面升级

微服务系统架构:

微服务架构风格是一种将一个单一应用程序开发为一组小型服务的方法,每一个服务运行在自己的进程中,服务间通信采用的轻量级通信机制(通常用Http资源API),这些服务围绕业务能力构建并且可通过全自动部署机制独立部署,这些服务公用一个最小型的集中式的管理,服务可用不同的语言开发,使用不同的数据存储技术

微服务架构的优点:

易于开发和维护:一个微服务只会关注一个特定的业务功能,所以他的业务清晰,代码量少,开发和维护单个微服务相当简单,而整个应用是若干个微服务构建而成的,所以整个应用也被维持在一个可控状态

单个微服务启动较快:单个微服务代码量较少,所以启动会比较快

局部修改容易部署

技术栈不受限

按需收缩:可根据需求,实现细粒度的扩展,例如:系统中的某个微服务遇到了瓶颈,可以结合这个微服务的业务特点,增加内存,升级CPU或者增加节点

可以承受高并发

微服务架构的缺点:

运维要求较高:更多的服务意味着更多的运维投入,在单体架构中,只需要保证一个应用的正常运行,而在微服务中,需要保证几十甚至几百个服务正常运行与协作,这给运维带来了很大的挑战

分布式固有的复杂性:使用微服务构建的是分布式系统,对于一个分布式系统,系统容错,网络延迟等都会带来巨大的挑战

接口调整成本高:微服务之间通过接口进行通信,如果修改某一微服务API,肯呢个所有使用该接口的微服务都需要调整

推荐阅读

微服务架构和相关的组件

微服务与领域抽象:支付系统2.0架构演进

浅谈微服务体系中的分层设计和领域划分

关于微服务架构入门篇

面试题

Spring Cloud面试题万字解析(2020面试必备)

85道Java微服务面试题整理(助力2020面试)

2019年面试官最喜欢问的28道ZooKeeper面试题

2019年Dubbo你掌握的如何?快看看这30道高频面试题!

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