MySQL专栏

第四弹:MySQL分库分表与主从复制

2020-06-13  本文已影响0人  lvyz0207

分库分表

简单理解,就是把原本存储于一个库的数据分块存储到多个库上,把原本存储于一个表的数据分块存储到多个表上。

说到分库分表之前,需要先说说分区的概念

分区:在单机中,将一张表的数据分成N个放置在磁盘内,分区的作用是将一张表分配为多个区块存储到一起。(缺点:数据库内部实现,研发执行不可控。可与分库分表结合使用)

分库:
数据库集群环境,一个库里表太多了,导致了海量数据,系统性能下降,把原本存储于一个库的表拆分存储到多个库上,通常是将表按照功能模块、关系密切程度划分出来,部署到不同库上。
少增量数据写入时的锁对查询的影响
由于单表数量下降,常见的查询操作由于减少了需要扫描的记录,使得单表单次查询所需的检索行数变少,减少了磁盘IO,时延变短

分表
水平拆分:
单表的容量不超过500W,否则建议水平拆分。把一个表复制成同样表结构的不同表,然后把数据按照一定的规则划分,分别存储到这些表中,从而保证单表的容量不会太大,提升性能;当然这些结构一样的表,可以放在一个或多个数据库中。
主要方法:MD5 hash方法、按照时间、按照用户ID拆分

垂直拆分:
按照业务线进行拆分,业务功能的使用频次。把主要的、热门的字段放在一起做为主要表。然后把不常用的,拆分到不同的次要表中;主要表和次要表的关系一般都是一对一的。

分库分表存在的问题。

分库分表

主从复制

slave 会从 master 读取 binlog 来进行数据同步

MySQL 复制是异步且是串行化的。

复制的基本原则(一主多从、主主复制)

复制的最大问题:延时、主从复制过程中的性能问题。

MySQL一主多从
hummingbird
上一篇 下一篇

猜你喜欢

热点阅读