微服务 - 漫画版(下)

本文涉及的产品
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 微服务 - 漫画版(下)

image.png

image.png



什么是微服务?微服务(Microservice Architecture)是近几年流行的一种架构思想,关于它的概念很难一言以蔽之。

究竟什么是微服务呢?我们在此引用 ThoughtWorks 公司的首席科学家 Martin Fowler 的一段话:


image.png



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.


谷歌翻译如下:


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


说了这么多概念,微服务有什么样的具体特点呢?


1.独立部署,灵活扩展传统的单体架构是以整个系统为单位进行部署,而微服务则是以每一个独立组件(例如用户服务,商品服务)为单位进行部署。


用一张经典的图来表现,就是下面这个样子:


image.png



图中左边是单体架构的集群,右边是微服务集群。


什么意思呢?比如根据每个服务的吞吐量不同,支付服务需要部署20台机器,用户服务需要部署30台机器,而商品服务只需要部署10台机器。这种灵活部署只有微服务架构才能实现。


而近几年流行的Docker,为微服务架构提供了有效的容器。


2.资源的有效隔离微服务设计的原则之一,就是每一个微服务拥有独立的数据源,假如微服务A想要读写微服务B的数据库,只能调用微服务B对外暴露的接口来完成。这样有效避免了服务之间争用数据库和缓存资源所带来的问题。



image.png



同时,由于每一个微服务实例在Docker容器上运行,实现了服务器资源(内存、CPU资源等)的有效隔离。


3.团队组织架构的调整微服务设计的思想也改变了原有的企业研发团队组织架构。传统的研发组织架构是水平架构,前端有前端的团队,后端有后端的团队,DBA有DBA的团队,测试有测试的团队。



image.png


而微服务的设计思想对团队的划分有着一定的影响,使得团队组织架构的划分更倾向于垂直架构,比如用户业务是一个团队来负责,支付业务是一个团队来负责。


image.png



当然,这种垂直划分只是一个理想的架构,实际在企业中并不会把团队组织架构拆分得这么绝对

微服务与面向服务架构SOA的区别



image.png

image.png


SOA是什么样子呢?可以是下面这样的Web Service:


image.png


也可以是下面这样的ESB企业服务总线:


image.png


总之,SOA架构强调的是异构系统之间的通信和解耦合,而微服务架构强调的是系统按业务边界做细粒度的拆分和部署。


image.png

image.png


微服务架构的不足


image.png

image.png

image.png

目录
相关文章
|
小程序 Java 数据库
从根儿上学习微服务01:微服务的“前世今生”
从根儿上学习微服务01:微服务的“前世今生”
101 0
|
存储 前端开发 JavaScript
微服务与领域驱动设计,架构实践总结
微服务与领域驱动设计,架构实践总结
|
运维 负载均衡 监控
微服务1:微服务及其演进史
微服务1:微服务及其演进史
147 0
微服务1:微服务及其演进史
|
存储 架构师 微服务
微服务大泥球,分层微服务,分群微服务
讨论一下微服务中服务间关系的三种模式:微服务大泥球,分层模式,分群模式。
134 0
|
数据库 开发者 微服务
微服务 - 漫画版(上)
微服务 - 漫画版(上)
155 0
微服务 - 漫画版(上)
|
架构师 程序员 微服务
架构师的独白:微服务架构是这样的...
项目和人类一样,总是会死亡的,有时候会突然死亡,有时候回自然死亡;在自然死亡这一边,有的人去世的很早,有的人则寿命很长,长寿的人,通常都是生活更规律的;项目也一样,框架更好的项目活的更久,框架不好的项目,上线同时就死亡了。
架构师的独白:微服务架构是这样的...
|
Java 测试技术 持续交付
拆完中台再拆微服务
这些年中台、微服务都是技术浪潮中的弄潮儿。两者的命运似乎是所有技术新词的缩影:先谈,再建,后拆,最后平静。 如中台,开始时聊什么都得带上中台,战略层喜欢谈,执行层也喜欢谈,再后面跟随一线大厂纷纷搭建自己的中台,然后就是反思,拆除中台,最后平静看待中台。 中台可以说已经经历完整的生命周期,而微服务周期也差不多,但对于“拆掉”,两者的声势与目标却不太相同。
160 0
|
XML 敏捷开发 JSON
微服务架构谈系列(3):SOA VS 微服务(2)
微服务架构谈系列(3):SOA VS 微服务(2)
191 0
微服务架构谈系列(3):SOA VS 微服务(2)
|
C++ 微服务
微服务架构谈系列(3):SOA VS 微服务(1)
微服务架构谈系列(3):SOA VS 微服务(1)
265 0
微服务架构谈系列(3):SOA VS 微服务(1)
|
运维 监控 架构师
微服务架构谈系列(3):SOA VS 微服务(3)
微服务架构谈系列(3):SOA VS 微服务(3)
228 0
微服务架构谈系列(3):SOA VS 微服务(3)
下一篇
无影云桌面