1.7微服务架构 Microservice 的设计策略| 学习笔记

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 快速学习1.7微服务架构 Microservice 的设计策略。

开发者学堂课程【Spring Cloud 微服务架构设计与开发实战 1.7微服务架构 Microservice 的设计策略】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/60/detail/1111


1.7微服务架构 Microservice 的设计策略

 

内容介绍

一、 微服务 Microservice 的设计原则

二、 微服务 Microservice 的拆分原则

三、 微服务 Microservice 设计的关注点

四、 微服务架构的新特性

五、 微服务 Microservice 设计的五大考量

六、总结

 

本节课重点关注如何进行微服务架构设计。第一阶段主要偏重理论体系,即和微服务相关的整个系统的重要的概念原则,为实战练习做铺垫。学习分为三大阶段,下节课主要讲解一些经典的设计模式。

 

一、 微服务 Microservice 的设计原则

1、需求第一

微服务架构属于分布式架构的一种,但是微服务架构是更复杂的分布式架构。微服务架构扎根于分布式架构。微服务实际上是诞生于 SOA,所以它具备某些 SOA 架构的一些特点。

所有的架构设计都有一个重要的原则,必须以需求为出发点,这是客观的理性的尊重事实的架构的设计原则,或者是不带任何偏见的所有架构师应该遵守的架构设计原则。所有的架构好与坏是相对的,相对于它所处的需求背景或者需求点。不能直接得出架构好与坏这样的结论,而是通过比较得出结论。不能因为现阶段微服务架构是比较流行的架构就得出微服务架构是最好的结论,这样的评价不够客观理性。因为微服务架构在某些业务场景中具备优势,所以相比传统架构它有很多优点,但是也存在一些缺点。总之,所有的架构设计必须以实际需求为第一出发点,不能离开需求设计架构。

出于某些原因,一些架构师在设计架构时并不是以需求作为第一出发点,而是将某些因素作为架构设计的第一出发点。比如很多公司的小网站,招聘网站,考勤系统等既没有用户量,业务也非常稳定,但还是使用了微服务架构。这是因为架构的负责人出于生存压力的需要,要设计一个高级的架构来为自己加分。

一些架构师在设计架构时,设计的复杂难懂,在架构中运用了各种包,各种项目拆分,前后端分离,模块拆分等使得调用关系复杂,难以维护。从单个请求的角度,请求调用非常复杂而且性能严重下降。这样会使开发团队变得庞大,架构难以维护难以扩展。从另外一个角度上,这种难以维护难以扩展的足够复杂的架构能够体现出架构师的能力比较强。

2、单一职责

OOP 中有个重要的原则是单一职责,在拆分服务时也是需要服务尽量体现单一职责。

3、粒度适中

粒度不是越细越好,也不是越粗越好。一个项目只有一个服务,或者一个项目一个函数一个服务或者一个方法一个服务也不可以,粒度太细无法进行维护。

4、协议统一

尽量做到统一协议,非必须不接受其他协议。微服务目前的协议主要是 Rest,有可能会引入其他的通信协议,这都是基于实际开发的需求而引入的。

5、独立开发

模块拆分以后,开发人员按照模块拆分,每人负责一个模块。每个人熟悉一块代码和业务逻辑,这样会提高开发熟练度。

6、独立部署

独立部署是微服务架构中很重要的原则。因为微服务拆分后可能会出现很多程序进程,而且并不是每个模块都更新,只需要迭代某个模块就可以了,体现了分而治之的思想。

如果统一部署,牵扯面会很大,导致部署效率很低,影响整个系统。

在微服务架构中有提到灰度发布等等这样的概念,也是体现了独立部署分而治之的思想。

 

二、 微服务 Microservice 的拆分原则

微服务如何拆分也是一道面试题。拆分服务粒度太小或太大都不合适,需要一个大概的拆分粒度。

1、按照业务模块拆分

2DDD 思路可以借鉴,不能照搬

3、单─职责 Single Responsibility

服务拆分一般是基于业务,与 DDD 原则不谋而合,DDD 是领域驱动设计。DDD 并不是架构设计模式,而是面向对象的一个设计原则思想,是用来解决复杂业务逻辑的拆分问题。DDD 本身不解决整个架构设计问题,而是针对于解决业务问题。之前删除架构,实际模块都是按照 DDD 原则拆分,体现了单一职责的理论。

4、电商架构设计: 账号模块,商品模块,订单模块,评论模块,快递模块,短信模块,支付模块,卡券模块,信用模块,酒店模块。

(1)、举例说明一:

比如在订单中,账号中,服务类都是完成订单相关的操作。一般的电商网站的架构设计比较明显,比如淘宝的拆分就比较多,支付宝,微信,拼多多,京东等拆分都比较多。订单所有的逻辑可能会微服务化,支付也是一样。支付宝某年双十一的并发量峰值达到58万,用户登录,点评,历史订单查询,信用等接口都不一样。不同微服务的业务迭代模式不同,并发量不同,存储量不同,要求也不同。

订单,双十一瞬间的搜索,支付的并发可能是非常高的。有效订单已经达到了每秒58万,搜索的并发量可能会超过百万甚至更高,用户点击购物车不一定会形成订单,所以前面可能需要更多的查询的请求压力。

每个APP客户端,比如淘宝客户端,天猫客户端,支付宝客户端可能都需要这个。淘宝推出了菜鸟统一订单的查询,淘宝需要订单查询的服务,支付宝中也会进行同步。淘宝中有酒店,飞猪等酒店模块,支付宝中也有酒店模块。支付宝中还包括社保,水电煤等众多公众模块。这种场景就像生态,接入的功能模块很多,得益于足够庞大的基础,分而治之的思想以及高并发,快速的业务迭代,微服务水到渠成,这是非常适合业务模式的架构。

(2)、举例说明二:

以上是举的电商相关的例子,社交也一样。像微信,陌陌等社交软件,陌陌的业务比微信复杂,它包含了很多功能比如支付,直播等,虽然陌陌的语音通话,视频通话等功能做的不是很好,但是其他功能很丰富。无论是微信还是其它社交 APP,从1.0版本诞生到今天都具有很明显的微服务架构。新的业务诞生早期可能只有两三台服务器,后期发展起来可能会拥有上千台服务器。

(3)、举例说明三:

很多平台游戏的前端是导流模式,加入一个模块进来把平台作为入口。

(4)、举例说明四:

抖音早期是通过直播带货将流量带给淘宝。现在是抖音做电商,交易算在抖音的平台中,会提高抖音的见微,直接影响整个平台的估值。交易量高,市值就会高。

总结拆分原则:一般是基于业务拆分也可以说是 DDD,但并不是完全照搬 DDD,不是和 DDD 完全一致的思想。DDD 中有很多其它的概念,其中,在拆分业务逻辑时 DDD 提倡业务边界。business domain 的意思是业务的范围。Domain 本身就是领域范围的意思。


三、 微服务 Microservice 设计的关注点

微服务架构的设计需要关注一个问题:为什么要进行微服务架构设计,作为微服务架构设计师,应该解决什么问题首先关注什么问题。

在设计微服务架构时需要除了考虑并发,还要考虑可用性,安全性,性能。性能一般是与高并发相关的,高并发高可用是一个典型的分布式架构,这几个关注点都会受到影响。接口的重幂性,幂等性在早期的 webservice,SOA 中已经存在。

安全性会变得更加复杂。由于微服架构设计拆分的更细,所以其中很重要的一个场景 SSO 可能也会进行扩展引入。

 

四、 微服务架构的新特性

1、微服务架构作为一个比较流行,比较新的架构具备如下特点:独立部署,粒度适中,服务隔离,单一职责,独立开发,边界清晰,服务自制。

(1)、服务隔离指各个微服务之间互不影响,某个服务断了或者高并发,扩容都不影响其他服务,各个服务是独立的,这也是分而治之的思想。

(2)、服务自制相当于政治上的地区自治,由于某些情况特殊所以实行自治。如果把有订单的服务,有支付的服务部署到一个进程中,某个服务出错就会影响到其他服务。把服务分开部署,清晰的体现出了服务隔离和服务自制。

(3)、如果拆分做的好,独立开发独立部署,边界清晰都不会有问题。

2、微服务的关注点:敏捷运维,敏捷开发,敏捷测试

采用微服务架构的很重要的一个点是敏捷开发,快速开发,这也是为什么要各自负责一个模块的原因。敏捷开发的本质是高效率的编程,提高生产率。

如果设计的一个架构开发完效率反而变低,说明架构一定有问题。如果某些团队公司使用完一个架构后发现效率变低,成本上升,说明该架构还存在优化的空间。很多公司,银行机构都存在这样的问题,使用的架构比较老,但是并不允许使用新架构。

 

五、 微服务 Microservice 设计的五大考量

1、微服务拆分

2、微服务高可用

3、微数据安全

4、微服务数据同步

5、微服务监控

在设计微服务架构时要考虑的详细。需要注意拆分微服务的粒度,如何解决服务的高可用问题。

一些人在设计架构时,拆除了数据库和服务,但是落地只有一台服务器,这样相当于没有使用微服务。一个架构师所采用的微服务架构必须能够说服别人,给出合适的理由。虽然有时候不得不使用一些不规范的架构,但是从客观角度要能够知道架构的好与坏。

微数据安全需要注意接口安全,数据安全。在微服务架构中做事务比较难,需要注意数据的隐私性问题,怎么样做数据同步。因为在微服务中拆的很多,所以监控日志就会更难做。

 

六、总结

本节课所讲的知识点涉及到大量面试题,需要去好好学习思考。无论是否使用微服务架构,都要知道它的好坏,了解什么时候需要拆除,什么时候不需要拆除,以及学习一些重要的设计模式和原则。

下节课讲解微服务架构中的经典设计模式,也是面试题。

相关文章
|
3天前
|
敏捷开发 监控 数据管理
构建高效微服务架构的五大关键策略
【4月更文挑战第20天】在当今软件开发领域,微服务架构已经成为一种流行的设计模式,它允许开发团队以灵活、可扩展的方式构建应用程序。本文将探讨构建高效微服务架构的五大关键策略,包括服务划分、通信机制、数据管理、安全性考虑以及监控与日志。这些策略对于确保系统的可靠性、可维护性和性能至关重要。
|
4天前
|
消息中间件 监控 持续交付
构建高效微服务架构:后端开发的进阶之路
【4月更文挑战第20天】 随着现代软件开发的复杂性日益增加,传统的单体应用已难以满足快速迭代和灵活部署的需求。微服务架构作为一种新兴的分布式系统设计方式,以其独立部署、易于扩展和维护的特点,成为解决这一问题的关键。本文将深入探讨微服务的核心概念、设计原则以及在后端开发实践中如何构建一个高效的微服务架构。我们将从服务划分、通信机制、数据一致性、服务发现与注册等方面入手,提供一系列实用的策略和建议,帮助开发者优化后端系统的性能和可维护性。
|
1天前
|
监控 API 持续交付
构建高效微服务架构:后端开发的新趋势
【4月更文挑战第23天】 随着现代软件开发实践的不断演进,微服务架构已经成为企业追求敏捷、可扩展和弹性解决方案的首选。本文深入探讨了如何构建一个高效的微服务架构,涵盖了关键的设计原则、技术选型以及实践建议。通过分析微服务的独立性、分布式特性和容错机制,我们将揭示如何利用容器化、服务网格和API网关等技术手段,来优化后端系统的可维护性和性能。文章旨在为后端开发人员提供一套全面的指南,以应对不断变化的业务需求和技术挑战。
|
6天前
|
机器学习/深度学习 运维 Prometheus
探索微服务架构下的系统监控策略
【4月更文挑战第18天】在当今快速迭代和持续部署盛行的软件工程实践中,微服务架构因其灵活性和可扩展性受到企业青睐。然而,随着服务的细粒度拆分和网络通信的增加,传统的监控手段已不再适用。本文将探讨在微服务环境中实施有效系统监控的策略,包括日志聚合、性能指标收集、分布式追踪以及异常检测等关键技术实践,旨在为读者提供构建稳定、可靠且易于维护的微服务系统的参考指南。
10 0
|
6天前
|
监控 持续交付 开发者
构建高效微服务架构:后端开发的新趋势
【4月更文挑战第18天】在数字化转型的浪潮中,微服务架构已成为企业提升系统灵活性、加速产品迭代的关键。此文深入探讨了构建高效微服务架构的实践方法,包括服务划分原则、容器化部署、持续集成/持续部署(CI/CD)流程以及监控与日志管理等关键技术点。通过分析具体案例,揭示了微服务在提高开发效率、降低维护成本及促进团队协作方面的显著优势。
|
7天前
|
负载均衡 Java 开发者
细解微服务架构实践:如何使用Spring Cloud进行Java微服务治理
【4月更文挑战第17天】Spring Cloud是Java微服务治理的首选框架,整合了Eureka(服务发现)、Ribbon(客户端负载均衡)、Hystrix(熔断器)、Zuul(API网关)和Config Server(配置中心)。通过Eureka实现服务注册与发现,Ribbon提供负载均衡,Hystrix实现熔断保护,Zuul作为API网关,Config Server集中管理配置。理解并运用Spring Cloud进行微服务治理是现代Java开发者的关键技能。
|
16天前
|
API 数据库 开发者
构建高效可靠的微服务架构:后端开发的新范式
【4月更文挑战第8天】 随着现代软件开发的复杂性日益增加,传统的单体应用架构面临着可扩展性、维护性和敏捷性的挑战。为了解决这些问题,微服务架构应运而生,并迅速成为后端开发领域的一股清流。本文将深入探讨微服务架构的设计原则、实施策略及其带来的优势与挑战,为后端开发者提供一种全新视角,以实现更加灵活、高效和稳定的系统构建。
20 0
|
14天前
|
Kubernetes 安全 Java
构建高效微服务架构:从理论到实践
【4月更文挑战第9天】 在当今快速迭代与竞争激烈的软件市场中,微服务架构以其灵活性、可扩展性及容错性,成为众多企业转型的首选。本文将深入探讨如何从零开始构建一个高效的微服务系统,覆盖从概念理解、设计原则、技术选型到部署维护的各个阶段。通过实际案例分析与最佳实践分享,旨在为后端工程师提供一套全面的微服务构建指南,帮助读者在面对复杂系统设计时能够做出明智的决策,并提升系统的可靠性与维护效率。
|
25天前
|
存储 监控 Kubernetes
探索微服务架构下的系统监控策略
在当今软件开发领域,微服务架构因其灵活性、可扩展性和容错性而日益受到青睐。然而,这种架构的复杂性也为系统监控带来了新的挑战。本文旨在探讨在微服务环境下实现有效系统监控的策略,以及如何利用这些策略来确保系统的健壮性和性能。我们将从监控的关键指标入手,讨论分布式追踪的重要性,并分析不同的监控工具和技术如何协同工作以提供全面的系统视图。
|
25天前
|
监控 Java 开发者
构建高效微服务架构:后端开发的新范式
在数字化转型的浪潮中,微服务架构以其灵活性、可扩展性和容错性成为企业技术战略的关键组成部分。本文深入探讨了微服务的核心概念,包括其设计原则、技术栈选择以及与容器化和编排技术的融合。通过实际案例分析,展示了如何利用微服务架构提升系统性能,实现快速迭代部署,并通过服务的解耦来提高整体系统的可靠性。