03-微服务架构构建之微服务拆分

文章目录

  • 前言
  • 一、微服务拆分的原则
  • 二、微服务拆分的时机
  • 三、微服务拆分的方法
  • 总结


前言

微服务架构是将一个单体应用程序拆分为一个个独立且保持松耦合的服务的一种架构方式,每个服务有着独立的数据库并且能独立运行部署。微服务架构的构建过程中,第一步也是最为重要的一步是进行服务拆分。只有将微服务按照合理的方式进行拆分,才能确保整个项目能够高效而正确地运行。


一、微服务拆分的原则

微服务拆分原则有以下几个:

  1. 单一职责原则:每个微服务应该有一个明确的职责范围,只负责自己的一部分业务功能,不涉及其他职责。

  2. 服务自治原则:每个微服务应该具备自我管理、独立部署、独立伸缩、独立运维的能力,不与其他服务强依赖。

  3. 服务可复用原则:每个微服务应该是可复用的,可以为其他服务提供通用的服务功能。

  4. 服务粒度原则:微服务应该按照业务功能划分,而不是按照技术、数据结构等因素划分,保持服务规模适度。

  5. 服务高内聚、低耦合原则:微服务内部业务功能高度内聚,与其他服务之间耦合度低,便于分布式部署和独立开发、维护。

  6. 服务易于测试原则:每个微服务应该具备自我测试的能力,包括单元测试、接口测试、集成测试等多种形式,确保服务质量。

  7. 服务可扩展原则:每个微服务应该能够按照业务需求进行扩展,包括水平扩展和垂直扩展两种方式,以应对高并发、大流量等场景。

同样,也可以参考一下,这篇文章对服务拆分原则的理解。以下摘自该文章。

  1. 使用有界上下文。

  2. 确定核心域并保持竞争优势。

  3. 对通用域进行成本优化。

  4. 考虑支持领域。

  5. 引入反腐层。

  6. 识别数据通信模式。

  7. 引入事件驱动架构。

  8. 使API简洁明了。

  9. 将相关的微服务合并为更大的服务。

  10. 引入无缝开发支持工具。

不管是哪种拆分原则,目标都是需要将相同或相似的服务聚合在一起,形成一个独立的自治服务。

二、微服务拆分的时机

通过《02-微服务架构的概念与优缺点》可以了解到微服务架构具备很多的优点,能够有效解决项目业务扩大所带来的问题。然而,并非所有公司都适合采用微服务架构,尤其是规模较小且业务相对固定的公司。对于这些公司来说,从服务层面,他们不会有更多变化,通过优化现有服务即可满足需求。从成本方面,构建微服务架构,需要很多资源和配套的中间件。因此,对于那些规模较大,业务服务复杂度高,同时业务也在不断更新或新增的项目,微服务架构则是非常适合的选择。

在确定使用微服务架构后,服务的拆分是一项重要任务。根据拆分原则,我们可以在恰当的时机进行服务拆分。然而,根据行业经验来看,并不建议在项目构建初期进行服务拆分。主要原因有以下几点:

  1. 项目构建初期,服务单一,数据量较少,及时是单体系统都可以支撑业务。

  2. 项目构建初期,服务没有形成体系,更没有规模服务,很难做到微服务的单一职责和服务自治。

  3. 业务架构不够成熟,目前提供的服务,很有可能会优化,甚至更改技术栈重构。

因此,项目构建初期无需将其拆分,因为强行拆分此时可能会产生适得其反的效果。而遇到下面这些情况就可以进行服务拆分了。

  1. 项目足够成熟并且业务稳定,团队成员不断扩大并且目前的服务想要扩展很难。只有在项目成熟的情况下,业务专家才可以从精确的划分出业务领域,进而将各个服务分解到业务领域内,最终形成各自独立的微服务。

  2. 项目要求CI/CD(持续集成/持续交付)。尤其是很多新兴的互联网公司,要求系统在尽可能不停机的情况下,还需要持续上线新的功能。使用敏捷开发,可以更好地让开发者在完成周期形的业务交付,而DevOps则可以将这些代码,进行自动化测试、构建和集成,不断的完成新的需求提交,并保证代码的质量和稳定性。

  3. 正式运行的项目,部分服务需要停机。当上线一些有问题的服务时,将该部分服务停机,这个情况对单体应用是非常有困难的。而微服务架构中,可以对存在问题的微服务进行下线处理,从而达到快速解决问题的目的。


三、微服务拆分的方法

在掌握了准确的微服务拆分时机和有了强有力的拆分原则后,拆分方法将成为下一个关键环节。现在微服务拆分的方法有很多种,常见的包括:

  1. 按业务功能拆分:将整个系统按照不同的业务模块进行拆分,每个模块对应一个微服务。这种方式能够有效地降低系统的复杂度,提高系统的可维护性和可扩展性。

  2. 按数据拆分:将整个系统的数据按照不同的领域进行拆分,每个领域对应一个微服务。这种方式能够提高系统的性能和可扩展性。

  3. 按用户界面拆分:将整个系统按照不同的用户界面进行拆分,每个用户界面对应一个微服务。这种方式能够实现快速迭代和响应用户需求的能力。

  4. 按技术栈拆分:将整个系统按照不同的技术栈进行拆分,每个技术栈对应一个微服务。这种方式能够提高开发效率和降低系统的复杂度。

  5. 按性能拆分:将整个系统按照不同的性能需求进行拆分,每个需求对应一个微服务。这种方式能够提高系统的性能和可扩展性。

从行业经验来看,可以确定领域驱动设计(Domain Driven Design,简称DDD)在微服务拆分方面具有显著优势。

DDD是一种软件开发方法论,它强调将软件划分为不同的领域,每个领域都由一个核心模型驱动。 微服务架构的核心概念是将单一的应用程序拆分为一组小型、自治的服务。而DDD则提供了一种方法来设计这些微服务的边界和交互。 领域驱动设计引入了领域模型的概念,该模型描述了业务领域的核心概念和实体,而不关注技术实现细节。这使得团队可以专注于业务逻辑,而不被底层技术细节所干扰。 通过将领域模型作为微服务拆分的基础,可以确保每个微服务都是高内聚的,并且只关注自己领域内的业务逻辑。这种拆分方式使得每个微服务都能够独立开发、部署和维护,从而提高了系统的可伸缩性和可靠性。 此外,DDD还强调了领域驱动设计的语言在业务团队和开发团队之间的沟通和理解的重要性。通过共享统一的语言和概念,可以确保业务需求能够准确地传达给开发团队,并且开发团队能够将其转化为可行的技术解决方案。 因此,DDD是一种非常适合成为微服务拆分的方法论。它能够帮助开发人员更好地理解业务需求,找到合适的服务边界,构建高质量的领域模型和微服务。


总结

以上就是今天要讲的关于微服务拆分的全部内容。通过了解微服务的拆分时机并掌握拆分原则,我们可以选择合适的拆分方式,从而顺利进行微服务的拆分。微服务的拆分时机一般是在系统庞大、业务复杂或者团队扩大的情况下,以应对系统的瓶颈和团队协作的问题。同时,在进行微服务拆分时,我们需要遵循一些原则,如单一职责原则、服务自治原则等,以确保拆分后的服务具有清晰的职责和松耦合的关系。最后,要根据实际情况选择合适的拆分方式,提出使用领域驱动设计作为方法论的优势。只有通过这样的准备和选择,才能够顺利进行微服务的拆分工作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/206759.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

偷窃别人的密码

在工作中都用到virtual machine吧,同事之间还互相借用机器,或者不借用但凭借自己的域账号能登录任意机器,而且每个域账号都有sudo权限? 那你要小心了! 因为我可以轻易记录下每个ssh登录到我机器,或者我在…

uniapp 输入框输入时,会将内容顶上去的解决方案

// 设置页面最小高度 export const setPageMinHeight () > {return {position: relative,min-height: uni.getSystemInfoSync().windowHeight px} }页面使用: import {setPageMinHeight} from "/utils/uniUtil";data() {return {minHeight: setPag…

Unity 状态系统

状态系统 原理食用方法Demo 原理 #mermaid-svg-lUbxJ8eMP3KqrEhY {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-lUbxJ8eMP3KqrEhY .error-icon{fill:#552222;}#mermaid-svg-lUbxJ8eMP3KqrEhY .error-text{fill:#55…

官方officevisio在线安装包

在线安装包,在线就是要有网络环境,你能搜到这篇博客,就初步具备网络环境 visio在线安装包.zip官方版下载丨最新版下载丨绿色版下载丨APP下载-123云盘 在线安装包如下,双击执行安装即可,可供选择的64/32位 软件的激活与…

netty使用

支持协议 TCP/UDPHTTP/HTTPSWebSocketSPDY/HTTP2MQTT/CoAP 服务端 常用类 ServerBootstrap 服务端配置类 //设置线程组、parentGroup处理连接、childGroup处理I/O group(EventLoopGroup parentGroup, EventLoopGroup childGroup) //Channel通过何种方式获取新的连接(NioSe…

【扩散模型】ControlNet从原理到实战

ControlNet从原理到实战 ControlNet原理ControlNet应用于大型预训练扩散模型ControlNet训练过程ControlNet示例1 ControlNet与Canny Edge2. ControlNet与Depth3. ControlNet与M-LSD Lines4. ControlNet与HED Boundary ControlNet实战Canny Edge实战Open Pose 小结参考资料 Cont…

Linux系统上RabbitMQ安装教程

一、安装前环境准备 Linux:CentOS 7.9 RabbitMQ Erlang 1、系统内须有C等基本工具 yum install build-essential openssl openssl-devel unixODBC unixODBC-devel make gcc gcc-c kernel-devel m4 ncurses-devel tk tc xz socat2、下载安装包 1)首先&a…

[linux] kaggle 数据集用linux下载

你可以通过以下步骤获取Kaggle的下载链接并在Linux中进行下载: 首先,确保你已经安装了Python和Kaggle API。如果没有安装,你可以通过以下命令安装: pip install kaggle 接着,你需要在Kaggle网站上获取API Token。登录…

时间相关类

内容 JDK7时间相关类JDK8时间相关类 第一章 Date类 1.1 Date概述 java.util.Date类 表示特定的瞬间,精确到毫秒。 继续查阅Date类的描述,发现Date拥有多个构造函数,只是部分已经过时,我们重点看以下两个构造函数 public Dat…

【PyTorch】 暂退法(dropout)

文章目录 1. 理论介绍2. 实例解析2.1. 实例描述2.2. 代码实现2.2.1. 主要代码2.2.2. 完整代码2.2.3. 输出结果 1. 理论介绍 线性模型泛化的可靠性是有代价的,因为线性模型没有考虑到特征之间的交互作用,由此模型灵活性受限。泛化性和灵活性之间的基本权…

Docker构建自定义镜像

创建一个docker-demo的文件夹,放入需要构建的文件 主要是配置Dockerfile文件 第一种配置方法 # 指定基础镜像 FROM ubuntu:16.04 # 配置环境变量,JDK的安装目录 ENV JAVA_DIR/usr/local# 拷贝jdk和java项目的包 COPY ./jdk8.tar.gz $JAVA_DIR/ COPY ./docker-demo…

Java基础50题: 21.实现一个方法printArray, 以数组为参数,循环访问数组中的每个元素,打印每个元素的值.

概述 实现一个方法printArray, 以数组为参数,循环访问数组中的每个元素,打印每个元素的值. 代码 public static void printArray(int[] array) {for (int i 0; i < array.length; i) {System.out.println(array[i] " ");}System.out.println();}public static…

【数据结构c实现】顺序表实现

文章目录 线性表线性表的顺序实现结点结构结点初始化增配空间Inc打印顺序表show_list线性表长度length尾部插入push_back头部插入push_front尾部删除pop_back头部删除pop_front按位置插入insert_pos按值查找find按位置删除delete_pos按值删除delete_val排序sort(冒泡&#xff1…

云上业务DDoS与CC攻击防护实践

案例背景&#xff1a;DDoS攻击来势汹汹&#xff0c;云上业务面临威胁 某网络科技有限公司&#xff0c;SaaS化创业公司&#xff0c;业务基于云上开展。其业务主要为各大网站提供安全验证服务&#xff0c;且市场占有率较高&#xff0c;服务客户遍布金融、直播、教育、电商等多个领…

【日常总结】mybatis-plus WHERE BINARY 中文查不出来

目录 一、场景 二、问题 三、原因 四、解决方案 五、拓展&#xff08;全表全字段修改字符集一键更改&#xff09; 准备工作&#xff1a;做好整个库备份 1. 全表一键修改 Stage 1&#xff1a;运行如下查询 Stage 2&#xff1a;复制sql语句 Stage 3&#xff1a;执行即可…

100. 相同的树(Java)

目录 解法&#xff1a; 官方解法&#xff1a; 方法一&#xff1a;深度优先搜索 复杂度分析 时间复杂度&#xff1a; 空间复杂度&#xff1a; 方法二&#xff1a;广度优先搜索 复杂度分析 时间复杂度&#xff1a; 空间复杂度&#xff1a; 给你两棵二叉树的根节点 p 和…

L1-028:判断素数

题目描述 本题的目标很简单&#xff0c;就是判断一个给定的正整数是否素数。 输入格式&#xff1a; 输入在第一行给出一个正整数N&#xff08;≤ 10&#xff09;&#xff0c;随后N行&#xff0c;每行给出一个小于231的需要判断的正整数。 输出格式&#xff1a; 对每个需要判断的…

Kotlin(十五) 高阶函数详解

高阶函数的定义 高阶函数和Lambda的关系是密不可分的。在之前的文章中&#xff0c;我们熟悉了Lambda编程的基础知识&#xff0c;并且掌握了一些与集合相关的函数式API的用法&#xff0c;如map、filter函数等。另外&#xff0c;我们也了解了Kotlin的标准函数&#xff0c;如run、…

vuepress-----22、其他评论方案

vuepress 支持评论 本文讲述 vuepress 站点如何集成评论系统&#xff0c;选型是 valineleancloud, 支持匿名评论&#xff0c;缺点是数据没有存储在自己手里。市面上也有其他的方案, 如 gitalk,vssue 等, 但需要用户登录 github 才能发表评论, 但 github 经常无法连接,导致体验…

[wp]“古剑山”第一届全国大学生网络攻防大赛 Web部分wp

“古剑山”第一届全国大学生网络攻防大赛 群友说是原题杯 哈哈哈哈 我也不懂 我比赛打的少 Web Web | unse 源码&#xff1a; <?phpinclude("./test.php");if(isset($_GET[fun])){if(justafun($_GET[fun])){include($_GET[fun]);}}else{unserialize($_GET[…