MYSQLg高级-----分库分表是什么?(基本概念篇)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MYSQLg高级-----分库分表是什么?(基本概念篇)

1 、基本概念


官网


1. 什么是ShardingSphere?

官网地址

地址

定义


Apache ShardingSphere 是一款开源的分布式数据库生态项目,由 JDBC 和 Proxy 这两款产品组成。

其核心采用可插拔架构,通过组件扩展功能。 对上以数据库协议及 SQL 方式提供诸多增强功能,包括数据分片、访问路由、数据安全等;对下原生支持

MySQL、PostgreSQL、SQL Server、Oracle 等多种数据存储引擎。 Apache ShardingSphere

项目理念,是提供数据库增强计算服务平台,进而围绕其上构建生态。

充分利用现有数据库的计算与存储能力,通过插件化方式增强其核心能力,为企业解决在数字化转型中面临的诸多使用难点,为加速数字化应用赋能


ShardingSphere 已于 2020 年 4 月 16 日成为 Apache 软件基金会的顶级项目。 欢迎通过邮件列表参与讨论。


ShardingSphere-JDBC

ShardingSphere-JDBC 是 Apache ShardingSphere 的第一个产品,也是 Apache ShardingSphere 的前身。定位为轻量级 Java 框架,在 Java 的 JDBC 层提供的额外服务。 它使用客户端直连数据库,以 jar 包形式提供服务,无需额外部署和依赖,可理解为增强版的 JDBC 驱动,完全兼容 JDBC 和各种 ORM 框架。


适用于任何基于 JDBC 的 ORM 框架,如:JPA, Hibernate, Mybatis, Spring JDBC Template 或直接使用 JDBC;

支持任何第三方的数据库连接池,如:DBCP, C3P0, BoneCP, HikariCP 等;

支持任意实现 JDBC 规范的数据库,目前支持 MySQL,PostgreSQL,Oracle,SQLServer 以及任何可使用 JDBC 访问的数据库。


ShardingSphere-JDBC
ShardingSphere-Proxy
数据库 任意 MySQL/PostgreSQL
连接消耗数
异构语言 仅 Java 任意
性能 损耗低 损耗略高
无中心化
静态入口


ShardingSphere-JDBC的优势在于对 Java 应用的友好度。


ShardingSphere-Proxy

ShardingSphere-Proxy 是 Apache ShardingSphere 的第二个产品。它定位为透明化的数据库代理端,提供封装了数据库二进制协议的服务端版本,用于完成对异构语言的支持。 目前提供 MySQL 和 PostgreSQL(兼容 openGauss 等基于 PostgreSQL 的数据库)版本,它可以使用任何兼容 MySQL/PostgreSQL 协议的访问客户端(如:MySQL Command Client, MySQL Workbench, Navicat 等)操作数据,对 DBA 更加友好。


向应用程序完全透明,可直接当做 MySQL/PostgreSQL 使用;

适用于任何兼容 MySQL/PostgreSQL 协议的的客户端。


ShardingSphere-JDBC
ShardingSphere-Proxy
数据库 任意 MySQL/PostgreSQL
连接消耗数
异构语言 仅 Java 任意
性能 损耗低 损耗略高
无中心化
静态入口

产品定位


构建异构数据库上层生态和标准

Apache ShardingSphere 产品定位为 Database Plus,旨在构建异构数据库上层的标准和生态。 它关注如何充分合理地利用数据库的计算和存储能力,而并非实现一个全新的数据库。 ShardingSphere 站在数据库的上层视角,关注他们之间的协作多于数据库自身。


在原有关系型数据库基础上提供扩展和增强

Apache ShardingSphere 旨在充分合理地在分布式的场景下利用关系型数据库的计算和存储能力, 并非实现一个全新的关系型数据库。 关系型数据库当今依然占有巨大市场份额,是企业核心系统的基石,未来也难于撼动,我们更加注重在原有基础上提供增量,而非颠覆。


统一管控的多端接入

Apache ShardingSphere 是多接入端共同组成的生态圈。 通过混合使用 ShardingSphere-JDBC 和 ShardingSphere-Proxy,并采用同一注册中心统一配置分片策略,能够灵活的搭建适用于各种场景的应用系统,使得架构师更加自由地调整适合于当前业务的最佳系统架构。



老版本官网内容:


1 、一套开源的分布式数据库中间件解决方案

2 、有三个产品:Sharding-JDBC和Sharding-Proxy(第3给本章不扩展暂不写)

3 、定位为关系型数据库中间件,合理在分布式环境下使用关系型数据库操作


2.什么是分库分表


(把一个大的数据库DB,可以先拆分为商品库和商家库,然后在进行表的拆分,商品DB拆分分商品表1,2;商家DB同理拆分2个表)


1 、数据库数据量不可控的,随着时间和业务发展,造成表里面数据越来越多,如果再去对数

据库表curd操作时候,造成性能问题。

2 、方案 1 :从硬件上(对于资金耗费较大)

3 、方案 2 :分库分表


为了解决由于数据量过大而造成数据库性能降低问题。

分库分表的方式

1 、分库分表有两种方式:垂直切分和水平切分


2 、垂直切分:垂直分表和垂直分库


3 、水平切分:水平分表和水平分库


4 、垂直分表

( 1 )操作数据库中某张表,把这张表中一部分字段数据存到一张新表里面,再把这张表另一 部分字段数据存到另外一张表里面

总而言之:就是把一个表中的多个字段拆分一下,根据你的表的内容可以拆分几个或者多个表,去对应每个表中的不同的数据;当你再修改课程的时候他的同一个字段的课程价格其实是不受影响的也就是不会上锁不影响到其他用户进行查询;


5 、垂直分库

( 1 )把单一数据库按照业务进行划分,专库专表


怎么说下呢? 针对业务场景不同在 业务场景中存放在不同的数据库当中 也就是有多个库,库中有多个表;例如上面的 课程库中 放课程相关数据表;相关的业务场景都会去课程库中进行查询;


6 、水平分库


水平分库:其实就是把一个数据库分成多个 结构类型一模一样的多个数据库;里面除了数据不一样其他都一样;存的时候可以根据ID%2得出偶数奇数的id 去针对他们id 存在不同的数据库当中;


7 、水平分表


同一个数据库当中,库不变,在库中创建多个一模一样的表,就像上图;我们可以把课程信息,课程描述表进行再次新增一个表;也可以根据id去存不同的数据当相同的表;也为了减少数据量比较大的情况;


垂直 库和表是不同的;水平 则是相同的;


分库分表应用和问题(总结)

1 、应用

( 1 )在数据库设计时候考虑垂直分库和垂直分表

( 2 )随着数据库数据量增加,不要马上考虑做水平切分,首先考虑缓存处理,读写分离,使用索引等等方式,如果这些方式不能根本解决问题了,再考虑做水平分库和水平分表


2 、分库分表问题

( 1 )跨节点连接查询问题(分页、排序)

查询表(库)中数据的时候需要进行多表关联多次查询才能得出结果;


( 2 )多数据源管理问题


在服务器中可能多遇到跨节点连接查询,多数据源连接问题;

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
存储 自然语言处理 关系型数据库
MySQL高级篇——索引的创建与设计原则
索引的分类与使用、MySQL8.0索引新特性、适合创建索引的情况、不适合创建索引的情况
|
7月前
|
关系型数据库 MySQL 数据库
关系型数据库MySQL开发要点之多表设计案例详解代码实现
关系型数据库MySQL开发要点之多表设计案例详解代码实现
77 2
|
关系型数据库 MySQL 数据库
MYSQLg高级-------分库分表之核心Sharding-Proxy 简介(二)
MYSQLg高级-------分库分表之核心Sharding-Proxy 简介(二)
112 0
MYSQLg高级-------分库分表之核心Sharding-Proxy 简介(二)
|
Java 数据库
MYSQLg高级-------分库分表之核心Sharding-Proxy 简介(三)
MYSQLg高级-------分库分表之核心Sharding-Proxy 简介(三)
142 0
|
存储 架构师 关系型数据库
MYSQLg高级-------分库分表之核心Sharding-Proxy 简介(一)
MYSQLg高级-------分库分表之核心Sharding-Proxy 简介(一)
274 0
|
存储 SQL SpringCloudAlibaba
MySQL高阶知识点(二):索引概述
**索引是一种用于快速查询和检索数据的数据结构。常见的索引结构有: B 树, B+树和 Hash** 通常来讲,索引就像一本中华字典的目录,通过目录可以快速定位查找某个汉字在哪一页,如果一页一页去查找某个汉字,效率之慢可想而知。我们可以通过创建索引提高查询速度,创建唯一索引保证字段唯一性,但是创建索引和维护索引需要耗费许多时间。当对表中的数据进行增删改的时候,如果数据有索引,那么索引也需要动态的修改,会降低 SQL 执行效率。索引需要使用物理文件存储,也会耗费一定空间。
116 0
|
存储 关系型数据库 MySQL
《MySQL高级篇》六、索引的创建与设计原则(三)
《MySQL高级篇》六、索引的创建与设计原则
《MySQL高级篇》六、索引的创建与设计原则(三)
|
SQL 关系型数据库 MySQL
《MySQL高级篇》六、索引的创建与设计原则(二)
《MySQL高级篇》六、索引的创建与设计原则
《MySQL高级篇》六、索引的创建与设计原则(二)
|
SQL 存储 关系型数据库
《MySQL高级篇》六、索引的创建与设计原则(一)
《MySQL高级篇》六、索引的创建与设计原则
《MySQL高级篇》六、索引的创建与设计原则(一)
|
SQL 机器学习/深度学习 关系型数据库
《MySQL高级篇》六、索引的创建与设计原则(四)
《MySQL高级篇》六、索引的创建与设计原则
《MySQL高级篇》六、索引的创建与设计原则(四)