如何构建普适的企业级微服务架构(下)——阿里云 MVP孙玄

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 阿里云MVP、奈学教育CEO孙玄结合自己的架构师经验,在直播中给大家介绍如何构建普适的微服务架构。

快速成为顶级架构师的内功修炼

查看直播——如何构建普适的企业级微服务架构

查看上篇文章

(二)同步架构->异步架构

从上图中我们可以看出图中所示的架构是一种同步架构,而同步架构显然是无法满足所有的业务场景的,那么我们怎么将同步架构变成异步架构呢?

image.png

如上图所示,在同步架构中,上游发送request给下游,下游再返回response给上游,而想将其变为异步架构也非常简单,就是在上游和下游之间加入一个MQ(Message Queue,消息队列)即可,这时虽然上游和MQ之间、下游和MQ之间仍然是同步架构,但是上游和下游已经变成了一个异步架构。

那么利于MQ,我们如何将上述商品发布服务的架构从同步架构转为异步架构呢?我们一共可以在APP与网关层、网关层与业务逻辑层、业务逻辑层与数据请求层、数据请求层与数据层四个地方加上MQ,使得其成为异步架构,且MQ对整个系统生命周期来说,加的越靠前越好,但是APP与网关层之间加一个MQ的意义不是很大,因为网关层一般不会成为架构的瓶颈。因此,最好的做法就是我们在网关层和业务逻辑层之间加一个MQ,相当于以此MQ为界将业务的生命周期分为了上游和下游,由同步架构转为了异步架构。

我们进一步思考,是不是所有的业务场景都可以用异步架构来做呢?当然不是。比如业务请求分为“读”请求和“写”请求,读请求就很难用异步架构来做,而写请求一般是可以的。但是,是否所有的写请求都可以用异步架构来做呢?大家在工作中需要进一步的思考。

二、微服务架构下分布式事务设计实践

根据上文我们了解了微服务架构的拆分方式,那么我们的DB该怎么去做呢?假如用户数据、商品数据、交易数据分布在不同的DB中,而我们有些操作既涉及到用户数据,又涉及到商品数据和交易数据,这种情况下显然我们是无法去做一些本地事务的,那么有什么解决方法呢?这时我们要进行分布式事务设计。

(一)分布式事务破局

分布式事务我们具体怎么去做呢?首先要进行分布式事务的破局,也就是实现长事务到短事务的转变。假设我们现在有一个事务,涉及到下单、减库存、支付三步,对应DB1、DB2、DB3三个数据库,那么我们想要设计一个分布式事务的第一步就是将长事务变成一个短事务,也就将下单、减库存、支付三步分开成三个事务,如果三个事务都成功了,那么分布式事务也就成功了,即便其中某一个事务N失败了,那么也只需要补偿关联的事务即可,也就是回滚N-1的事务。

(二)分布式事务设计实例

image.png

这里我们举一个异步场景的例子,如上图所示的商品交易场景,包括下单和支付两个业务,在用户下单之后,产生一个DB1,然后将消息传输给MQ,再由支付业务去消费MQ的消息,并操作自身的DB。

这种场景下,支付和下单是本地事务,但是MQ实际上不是一个本地事务,那么这时候我们如何去进行分布式事务设计呢?有人说可以将发送message和下单对DB1的操作放在一个本地事务里面,也就上图虚线框中部分。如果不细想,好像这样的操作也没有问题,但是在某些时候会出现问题,比如消费订单消息超时了,前面取消了订单,但是实际上后面的支付成功了,这样就会造成数据库的不一致,带来严重的业务影响。

那么这种情况下,我们怎么去设计分布式事务呢?一种比较好的方式是利用本地事务消息表来做。比如说刚才的下单业务,我们可以将下单和产生message都固化到本地数据中,下单对应一个表(本地事务操作表),产生message对应一个表(本地事务消息表),这样就转变成了一个本地事务,如果下单和产生message都成功,本地事务才成功,两者有一个失败,本地事务就失败了。如下图所示,本地操作和发送消息通过本地事务实现强一致性,再通过MQClient和MQ Server,就实现了分布式事务的设计。

image.png

三、要点总结

本次直播中主要讲解了:

(1)在构建普适的企业级微服务架构时如何进行架构的拆分,包括按照业务进行拆分的垂直拆分和按照功能(API)进行拆分的水平拆分两种方式。在拆分完成之后,要根据业务场景来具体地考虑是使用同步架构还是异步架构。

(2)在进行分布式事务设计的时候我们可以采取将长事务拆分成短事务的方式来完成架构设计,并列举了一个异步场景下用本地事务消息表来完成分布式事务设计的实例。

更多的详细文档大家可以扫描下面二维码关注孙玄老师的公众号《架构之美》和阿里云MVP技术圈来查看。

image.png

四、QA

下面是直播中的一些问答整理:

问1:现在微服务有什么难点没有解决或者说解决方式不够优雅呢?

答1:这个问题比较大,比如服务本身的设计和服务治理的分离就没有被很好的解决,类似的还有其他很多都没有被优雅的解决。

问2:使用MQ之后,订单状态更新不及时,怎么处理?

答2:首先,你要找到订单状态更新不及时的原因是什么,是因为消息量太大,还是因为下游消费的速度不够,然后针对性的解决。

问3:微服务治理主要有哪些方案?

答3:治理这个话题比较大,通常说的治理除了功能之外,也包括一些其他的治理,比如监控、熔断、限流等。最好的治理方式就是让你的业务同学不需要关注服务治理,比如Istio方案。

问4:微服务一般按照领域来进行设计吗?

答4:领域设计是一个比较好的思路,但是在实际中是比较复杂的,最好的方式还是刚才我们讲的方式,便于更好地去落地。

问5:请问亿级数据量用什么数据库?

答5:我个人认为亿级数据量并不大,用什么数据库都能扛得住,比如MySQL等,问题在于这个亿级的数据到底是怎么样的一个业务场景,需要提供什么样的特性,否则很难得到一个具体的回答。

问6:通常分库和分表的方案是什么呢?

答6:通常分库是按照业务来进行垂直拆分,往往是按照领域来进行拆分的,比如拆分成用户、商品、交易等;分表最好是按照查询维度来进行拆分,比如按照用户ID、商品ID等。另外,对于分库和分表,阿里云有比较好的解决方案,大家可以多多关注一下。

问7:gPRC多语言微服务需要部署在注册中心吗?可以直接使用K8s么?

答7:在我看来,k8s等docker的东西解决的是运维部署的问题,如果你的公司原来已经有了注册中心,那么没有必要为了使用k8s而把原来的注册中心推翻重来;如果原来没有的话,那就可以直接使用k8s service。

关键词:微服务,分布式事务,垂直拆分,水平拆分,MQ

快速成为顶级架构师的内功修炼

查看直播——如何构建普适的企业级微服务架构

查看上篇文章

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
27天前
|
弹性计算 运维 监控
阿里云云服务诊断工具:合作伙伴架构师的深度洞察与优化建议
作为阿里云的合作伙伴架构师,我深入体验了其云服务诊断工具,该工具通过实时监控与历史趋势分析,自动化检查并提供详细的诊断报告,极大提升了运维效率和系统稳定性,特别在处理ECS实例资源不可用等问题时表现突出。此外,它支持预防性维护,帮助识别潜在问题,减少业务中断。尽管如此,仍建议增强诊断效能、扩大云产品覆盖范围、提供自定义诊断选项、加强教育与培训资源、集成第三方工具,以进一步提升用户体验。
670 243
|
30天前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 云原生 API 网关 2024 年 11 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要
|
2月前
|
弹性计算 持续交付 API
构建高效后端服务:微服务架构的深度解析与实践
在当今快速发展的软件行业中,构建高效、可扩展且易于维护的后端服务是每个技术团队的追求。本文将深入探讨微服务架构的核心概念、设计原则及其在实际项目中的应用,通过具体案例分析,展示如何利用微服务架构解决传统单体应用面临的挑战,提升系统的灵活性和响应速度。我们将从微服务的拆分策略、通信机制、服务发现、配置管理、以及持续集成/持续部署(CI/CD)等方面进行全面剖析,旨在为读者提供一套实用的微服务实施指南。
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
144 5
|
1月前
|
监控 安全 持续交付
构建高效微服务架构:策略与实践####
在数字化转型的浪潮中,微服务架构凭借其高度解耦、灵活扩展和易于维护的特点,成为现代企业应用开发的首选。本文深入探讨了构建高效微服务架构的关键策略与实战经验,从服务拆分的艺术到通信机制的选择,再到容器化部署与持续集成/持续部署(CI/CD)的实践,旨在为开发者提供一套全面的微服务设计与实现指南。通过具体案例分析,揭示如何避免常见陷阱,优化系统性能,确保系统的高可用性与可扩展性,助力企业在复杂多变的市场环境中保持竞争力。 ####
46 2
|
1月前
|
弹性计算 Kubernetes API
构建高效后端服务:微服务架构的深度剖析与实践####
本文深入探讨了微服务架构的核心理念、设计原则及实现策略,旨在为开发者提供一套系统化的方法论,助力其构建灵活、可扩展且易于维护的后端服务体系。通过案例分析与实战经验分享,揭示了微服务在提升开发效率、优化资源利用及增强系统稳定性方面的关键作用。文章首先概述了微服务架构的基本概念,随后详细阐述了其在后端开发中的应用优势与面临的挑战,最后结合具体实例,展示了如何从零开始规划并实施一个基于微服务的后端项目。 ####
|
2月前
|
监控 持续交付 API
深入理解微服务架构:构建高效、可扩展的系统
深入理解微服务架构:构建高效、可扩展的系统
57 3
|
2月前
|
消息中间件 监控 安全
构建高效微服务架构:最佳实践与挑战
在现代软件开发中,微服务架构因其高度的可扩展性、灵活性和敏捷性而受到青睐。本文深入探讨了构建高效微服务架构的关键策略,包括服务的划分、通信机制、数据管理、部署与监控等方面的最佳实践。同时,文章也分析了在实施过程中可能遇到的挑战,如服务间的依赖管理、数据一致性问题、安全考量及性能优化等,并提出了相应的解决方案。通过实际案例分析,本文旨在为开发者提供一套实用的指南,帮助他们在构建微服务系统时能够有效规避风险,提升系统的健壮性和用户体验。
|
2月前
|
Dubbo Cloud Native 应用服务中间件
阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。
在云原生时代,微服务架构成为主流。阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。示例代码展示了如何在项目中实现两者的整合,通过 Nacos 动态调整服务状态和配置,适应多变的业务需求。
62 2
|
2月前
|
监控 持续交付 数据库
构建高效的后端服务:微服务架构的深度解析
在现代软件开发中,微服务架构已成为提升系统可扩展性、灵活性和维护性的关键。本文深入探讨了微服务架构的核心概念、设计原则和最佳实践,通过案例分析展示了如何在实际项目中有效地实施微服务策略,以及面临的挑战和解决方案。文章旨在为开发者提供一套完整的指导框架,帮助他们构建出更加高效、稳定的后端服务。