`
yixibo
  • 浏览: 185773 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

在微服务中数据库拆分示例

 
阅读更多

微服务是当前非常流行的技术框架,通过服务的小型化、原子化以及分布式架构的弹性伸缩和高可用性,可以实现业务之间的松耦合、业务的灵活调整组合以及系统的高可用性。为业务创新和业务持续提供了一个良好的基础平台。本文分享在这种技术架构下的数据架构的设计思想以及设计要点,本文包括下面若干内容。 

    • 微服务技术框架中的多层数据架构设计
    • 数据架构设计中的要点
    •        要点1:数据易用性

 

             要点2:主、副数据及数据解耦

 

             要点3:分库分表

 

             要点4:多源数据适配

 

             要点5:多源数据缓存

 

           要点6:数据集市


为了容易理解,本文用一个简化的销售模型来阐述,如下图。图1显示了客户、卖家、商品、定价、订单的关系(这里省略支付、物流等其他元素)。 

 

图1 销售模型


在这个销售模型中,卖家提供商品、制定价格,客户选择产品购买、形成销售订单。根据微服务的理念设计,可以划分为客户服务、卖家服务、商品服务、定价服务、订单服务,以及公共服务(比如认证、权限、通知等),如图2所示。 

 

图2 微服务功能


微服务架构中的多层数据架构设计 

分布式架构一般把系统分为 Saas(Software-as-a-Service)、Paas(Platform-as-a-Service)、Iaas(Infrastructure as a Service )三层。其中 Saas 层负责对外部提供业务服务,Paas 层提供基础应用平台,Iaas 层提供基础设施。微服务垂直嵌入这三层服务之中,相互独立。因此数据架构设计时需要考虑三层服务对数据的关注点,又要考虑微服务的独立性。 

数据架构的分层设计 

 

图3 微服务技术框架


如图3所示,Iaas 层提供程序运行的物理基础环境(这边涉及很多硬件·网络内容,在本文中省略)。Pass 层细分为三层,基础服务层,主要负责数据存储处理;事务框架层,主要负责微服务的注册·调度管理、分布式事务处理;应用服务层、主要实现各个微服务的 API,供其它微服务直接调用以及 Saas 层的服务调用。Saas 服务就是公开对外提供的业务服务。 

数据架构自下向上相应的分为 Raw Data 层、Logic Data(inner)层和 Logic Data(outer)层(Iaas 中主要以基础硬件环境为主,在本文中省略)。Raw Data 层是基于数据库、文件或者其他形式数据内容。Logic Data(inner)层是微服务 API 使用的逻辑数据,比如客户数据、订单数据等等。Logic Data(outer)层是对外服务提供数据,比如客户订单数据。因此,我们的数据架构的分层结果如图4所示。 

 

图4 数据分层架构


除此之外,很多情报会以画面或报表的形式展现出来。因此在 Logic Data(outer) 之上,可以构建 Information Block(常用的信息块)、通过 View type(显示模式)的设定后,最终 View 展现出来。 

如图4所示,越靠近对外服务层,客户对设计者的影响度越大,越需要从使用性、易用性、适用性等考虑。反之,越远离对外服务层,设计上更关心数据的存储。 

数据三层架构的好处是实现数据从系统实现到业务实现的逐层过渡,实现业务数据和系统数据间的松耦合。同时实现业务的灵活扩展和系统的灵活扩展。 

数据架构设计中的要点 

上面讲述了数据架构的分层设计,下面讲述数据架构设计中的要点。 

要点1:数据易用性 

数据无论用什么方式实现,其最终目的都是为业务(或者是客户)使用的。因此,在对外提供服务的时候,数据的易用性非常关键。 

 

图5 数据易用性


如图5所示,客户信息在 Logic Data(inner) 层中为了数据的柔软性和非冗余,把人员信息拆成若干子表来存储。比如,人员地址表可以无限多的存储客户地址信息。这样的好处在于每次人员地址更新时,不用直接更新人员地址,而是生成一个新的地址数据,原有的地址信息作为历史数据得到保存,易于数据快速恢复和历史信息追踪。但在 Logic Data(outer)层提供外部数据的时候,首先考虑的是一次性能提供足够用的信息(毕竟查询的操作大大高于修改的操作),减少业务场景中不需要的信息。比如对一般客户只提供三个常用地址的时候,数据设计中地址1、地址2和地址3放在一张表中。 

要点2:主、副数据及数据解耦 

每个微服务 API 的数据完全独立是不太现实的,比如订单中需要有商品、客户(包括收货者)、卖家以及价格等数据。如果这些数据都在订单服务 API 中管理,那么客户情报的变更、价格调整等信息都要同步给订单 API 中数据,数据的耦合度就会变得非常高。在数据设计的时候,需要考虑降低数据间的相互依赖性。因此,首先需要确定每个微服务 API 的主数据和副数据。主数据指微服务 API 的核心数据,这种数据的增删改主要集中在某个微服务 API 中,比如订单服务 API 中的订单数据。副数据指参照或者映射其他微服务 API 的数据,比如订单服务 API 中的商品数据、价格数据等。其次,为了降低数据之间的耦合度,用数据关联表来表征数据间的关系。如果想去掉数据间的关联关系,直接去掉关联表即可,对数据本身的没有任何影响。具体如图6所示。 

 

图6 主、副数据及数据解耦


要点3:分库分表 

随着业务数据量不断增加,单一数据库或单一数据表中会积累大量的数据,比如订单数据,随着时间推移和客户数量的增加,产生的订单数据也会越来越多。当数据累积到一定程度后,数据操作的性能会大幅下降,也就是我们常说的数据库“带不动了”。所以,在数据架构设计阶段就应该考虑数据的分库分表。 

如图7所示,分库,即我们把订单数据分为当前数据应用库、历史数据库、历史归档数据库。当前数据应用库用来支持新订单的生成以及执行中订单的增删改查。历史数据库(这里举例分为最近3个月和最近1年)当客户想看过往订单的时候才使用。历史归档数据(按年间归档)原则上不直接对客户公开,用于备查、统计分析。对于当前数据应用库,可以继续再分库,按客户号范围来分库。这样每个数据库的大小都能得到有效控制。分表,即把一条信息分别存储在两张或多张表中。比如把订单信息按基本信息和详细信息分表,就可以适用于订单的基本信息查询和订单详细信息查询。总之,分库分表的核心就是控制单一数据库的负荷(数据量和数据信息量),通过多表多库来应对业务数据量的增长。 

 

图7 分表分库


要点4:多源数据适配 

传统的关系型数据库之外,有多种多样的数据源,比如图像、声音、视频等多媒体数据文件或数据流,CSV、TXT、Doc、Excle、PDF、XML 等各种异构数。这些数据都需要做相应的处理,转换成可管理的数据信息。因此在数据架构设计的时候,需要给不同性质的数据源配置相对应的读写适配器,同时也需要有统一调度的地方,如图8所示。 

 

图8 多源数据适配


要点5:多源数据缓存 

数据处理的性能除了处理逻辑的复杂度以外,还有很大一部分是目标数据的操作时长(含对硬件磁盘设备的读写以及网络的传输)。网络速度特别是光纤的使用后已经大幅度提高,但机器磁盘的读写效率并没有显著提高,因此减少磁盘读写是提高效率的一个重要途径。数据缓存就是把常用的数据(不会经常更改的数据)、最近使用数据放到内存中。这样就可以大幅降低系统对硬件磁盘设备的操作开销,提高整个数据系统的性能,如图9所示。 

 

图9 数据缓存


要点6:数据集市 

数据集市是一个很大的话题。当现有的数据不能简单地通过几个表数据关联以及简单加工后就可以供业务使用的时候,就需要考虑构建数据集市。数据集市以数据运用的观点来分析加工数据,通过多源数据的导入、清洗、加工、视图做成等一系列的数据操作后,为业务提供可用的、稳定的数据源。例如,对销售分析中、什么样的客户喜欢什么样的商品、价格对销售金额的影响、销售金额跟地区日期的关联关系等多维度分析,就要用数据集市的概念,如图10所示。 

 

图10 数据集市


数据承载着信息,好的数据架构设计会使业务系统变得更加流畅、更加容易理解和维护。本文只是总结一些在实际工程中的体会,供大家分享。如果有不足之处、也请大家补充、赐教。

分享到:
评论

相关推荐

    创建一个微服务流程,demo示例

    在这个"创建一个微服务流程,demo示例"中,我们将深入探讨微服务的核心概念以及如何构建一个简单的微服务架构。 1. **微服务概念**: 微服务的核心理念是“单一职责原则”,每个服务专注于完成特定的业务功能。这...

    微服务Spring Cloud 程序前后端代码代码示例

    首先,微服务是一种软件开发方法论,它提倡将单一应用程序拆分为一组小型、独立的服务,每个服务运行在其自己的进程中,且都拥有自己的数据库。这样的架构使得服务之间可以独立部署,降低了系统的耦合度,提高了开发...

    微服务根据业务模块拆分服务,并通过远程调用进行交互

    在“微服务根据业务模块拆分服务”这一概念中,关键点在于理解如何有效地将大型的单体应用解耦成一系列可独立管理的小型服务。每个微服务都是业务能力的一个单元,如订单服务、用户服务等。例如,"cloud-order.sql...

    微服务专栏-实用篇-服务拆分及远程调用

    三、服务拆分示例 在"cloud-demo"这个项目中,我们可以看到一个微服务实战的例子。通常,这个示例会包括以下部分: 1. 服务注册与发现:例如使用Eureka或Consul,这些组件帮助微服务实例发现彼此,实现服务间的...

    【认识微服务-2.服务拆分和远程调用】

    在提供的文件`cloud-order.sql`和`cloud-user.sql`中,我们可以推测这是为订单服务和用户服务创建的数据库脚本,分别代表了两个独立的微服务,它们各自处理与订单和用户相关的业务逻辑。 服务拆分的好处包括更好的...

    微服务电商示例-simple-microservice.zip

    本示例项目——"simple-microservice",是一个精心设计的电商系统,它展示了如何将单一应用程序拆分为一组小型、独立的服务,每个服务都运行在其自己的进程中,并通过轻量级机制(如HTTP RESTful API)进行通信。...

    微服务实例demo

    在微服务架构中,每个服务都是一个独立的单元,拥有自己的业务逻辑、数据库和API接口,可以独立部署和扩展。这种架构模式强调服务的松耦合,使得团队可以更快速地迭代和维护系统。 这个压缩包中的关键组件很可能...

    SpringBoot微服务架构应用视频

    微服务架构则是将单一应用程序拆分为一组小的服务,每个服务都在自己的进程中运行,服务之间通过轻量级的方式(通常是HTTP RESTful API)进行通信。 本套"SpringBoot微服务架构应用视频"教程主要针对初学者,旨在...

    ecomerce-microservice:微服务架构的简单示例

    在IT行业中,微服务架构是一种将单一应用程序分解为一组小型、独立的服务的开发方式,每个服务都运行在其自己的进程中,并且可以独立部署。这个概念在近年来变得越来越流行,特别是对于电商这样的复杂系统,它能够...

    微服务项目(学成在线)资料.zip

    微服务架构是一种将大型复杂应用分解为一组小的、独立的服务的开发方法,每个服务都可以在其自身的进程中运行,服务之间通过轻量级通信机制(如HTTP/RESTful API)进行交互。这种架构允许团队独立地开发、部署和扩展...

    microservice-reactive:使用Spring Cloud开发微服务和RxJava功能示例

    微服务是一种将单一应用程序拆分为一组小型、独立的服务的方法,每个服务都在自己的进程中运行,并且可以通过轻量级机制(通常是HTTP RESTful API)进行通信。这种方式增强了系统的可伸缩性、可维护性和容错性。 在...

    Docker+Kubernetes(k8s)微服务容器化实践1

    微服务架构是一种软件设计方式,它提倡将单一应用拆分为一组小的、独立的服务,每个服务都运行在自己的进程中,通过轻量级的通信机制交互,如HTTP/2或gRPC。微服务的特点包括单一职责、轻量级通讯、隔离性和技术多样...

    IT项目--系统安装部署手册(微服务模板).docx

    本文档旨在指导 IT 项目中的系统安装部署工作,特别是在微服务架构下的安装部署。微服务架构是一种软件架构风格,它将应用程序拆分为多个小的独立服务,以提高系统的灵活性、可扩展性和可维护性。 1. 系统安装部署...

    微服务入门介绍.pptx

    在实际项目中,例如介绍的eMall示例,可以将微服务应用于各个业务场景,如商品服务、评价服务、支付服务和订单服务,每个服务都能独立处理其业务逻辑,提供高效、灵活的电商解决方案。然而,实施微服务架构需要考虑...

    NET Core3.1微服务

    这可能是一个示例项目,展示了如何在.NET Core 3.1中实现微服务的各个组件,包括服务注册、负载均衡、API网关以及可能的RabbitMQ集成。通过分析这个项目,开发者可以学习如何在实践中运用微服务架构。 8. **Consul...

    SpringCloud01.pdf

    服务拆分的示例包括 cloud-demo 项目,其中包括订单微服务和用户微服务。订单微服务和用户微服务都必须有各自的数据库,相互独立。订单服务和用户服务都对外暴露 Restful 的接口。 远程调用是微服务架构中的重要...

    Nameko是一个Python的微服务框架

    微服务架构是一种流行的设计模式,它提倡将单一应用程序拆分为一组小的服务,每个服务都可以独立部署、扩展和维护,通过轻量级通信机制(如HTTP RESTful API或消息队列)进行交互。 Nameko的核心特性之一是其服务化...

    01-sca.zip 微服务

    微服务架构是一种将单一应用程序分解为一组小型、独立的服务的方法,每个服务都运行在其自己的进程中,并且可以独立部署。这种架构模式促进了敏捷开发、部署自动化和组织间的协作,使得大型复杂应用的管理和扩展变得...

    若依框架(RuoYi-Cloud 微服务版本)

    - **集成示例**:在若依框架中,通过简单的配置即可启动Spring Boot应用,并利用Spring Cloud Alibaba提供的组件来实现服务注册、服务调用、配置管理等功能。 ##### 2. 权限管理系统 - **RBAC模型**:若依框架采用...

Global site tag (gtag.js) - Google Analytics