如何构建普适的企业级微服务架构(下)——阿里云 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搭建和管理企业级网站应用
目录
相关文章
|
3天前
|
弹性计算 持续交付 API
构建高效后端服务:微服务架构的深度解析与实践
在当今快速发展的软件行业中,构建高效、可扩展且易于维护的后端服务是每个技术团队的追求。本文将深入探讨微服务架构的核心概念、设计原则及其在实际项目中的应用,通过具体案例分析,展示如何利用微服务架构解决传统单体应用面临的挑战,提升系统的灵活性和响应速度。我们将从微服务的拆分策略、通信机制、服务发现、配置管理、以及持续集成/持续部署(CI/CD)等方面进行全面剖析,旨在为读者提供一套实用的微服务实施指南。
|
2天前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
25 5
|
10天前
|
监控 Java 微服务
从零构建微服务架构:一次深度技术探索之旅####
本文作为一篇深度技术分享,引领读者踏上自底向上搭建微服务架构的征途,旨在通过实战经验剖析,揭示微服务转型背后的技术挑战与解决方案。不同于常规摘要仅概述内容,本文摘要将直接以故事化手法,简述作者从单体应用困境出发,逐步迈向微服务化的心路历程,涵盖关键决策点、技术选型考量及实践收获,激发读者对微服务架构设计与实现的浓厚兴趣。 ####
|
14天前
|
消息中间件 监控 安全
后端架构演进:从单体到微服务####
在数字化转型的浪潮中,企业应用的后端架构经历了从传统单体架构到现代微服务架构的深刻变革。本文探讨了这一演进过程的背景、驱动力、关键技术及面临的挑战,揭示了如何通过微服务化实现系统的高可用性、扩展性和敏捷开发,同时指出了转型过程中需克服的服务拆分、数据管理、通信机制等难题,为读者提供了一个全面理解后端架构演变路径的视角。 ####
37 8
|
15天前
|
Cloud Native 安全 API
云原生架构下的微服务治理策略与实践####
—透过云原生的棱镜,探索微服务架构下的挑战与应对之道 本文旨在探讨云原生环境下,微服务架构所面临的关键挑战及有效的治理策略。随着云计算技术的深入发展,越来越多的企业选择采用云原生架构来构建和部署其应用程序,以期获得更高的灵活性、可扩展性和效率。然而,微服务架构的复杂性也带来了服务发现、负载均衡、故障恢复等一系列治理难题。本文将深入分析这些问题,并提出一套基于云原生技术栈的微服务治理框架,包括服务网格的应用、API网关的集成、以及动态配置管理等关键方面,旨在为企业实现高效、稳定的微服务架构提供参考路径。 ####
42 5
|
15天前
|
传感器 算法 物联网
智能停车解决方案之停车场室内导航系统(二):核心技术与系统架构构建
随着城市化进程的加速,停车难问题日益凸显。本文深入剖析智能停车系统的关键技术,包括停车场电子地图编辑绘制、物联网与传感器技术、大数据与云计算的应用、定位技术及车辆导航路径规划,为读者提供全面的技术解决方案。系统架构分为应用层、业务层、数据层和运行环境,涵盖停车场室内导航、车位占用检测、动态更新、精准导航和路径规划等方面。
66 4
|
13天前
|
Kubernetes API Docker
构建高效后端服务:微服务架构的深度实践与优化####
本文深入探讨了微服务架构在现代后端开发中的应用,通过剖析其核心概念、设计原则及实施策略,结合具体案例分析,展示了如何有效提升系统的可扩展性、可靠性和维护性。文章还详细阐述了微服务拆分的方法论、服务间通信的最佳实践、以及容器化与编排工具(如Docker和Kubernetes)的应用技巧,为读者提供了一份全面的微服务架构落地指南。 ####
|
4天前
|
监控 持续交付 API
深入理解微服务架构:构建高效、可扩展的系统
深入理解微服务架构:构建高效、可扩展的系统
19 0
|
10天前
|
监控 测试技术 持续交付
深入理解微服务架构:构建高效、可扩展的系统
深入理解微服务架构:构建高效、可扩展的系统
29 0
|
20天前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
78 6