Skip to content

Latest commit

 

History

History
62 lines (34 loc) · 2.6 KB

数据库架构.md

File metadata and controls

62 lines (34 loc) · 2.6 KB

数据库架构


主要会经历以下几个步骤:

  • 早期的单台MySQL服务器(Just Running)
  • 主从复制
  • 读写分离
  • SSD优化
  • 按业务垂直分库
  • 水平sharding分库(物理层面),逻辑上还是一张表

MySQL主从复制

传统单库很容易出现单点问题,所以会增加备库,利用主从复制,将写数据实时同步到备库里,同时主备库间增加心跳检测,一旦检测到主库不可用时,自动切换到备库。大大提高了系统的可用性。

image

主从复制也带来其他一系列性能瓶颈问题:

  • 写入无法扩展

  • 复制延时

MySQL读写分离

原理是让master数据库处理写操作,slave数据库处理读操作。master将写操作的变更同步到各个slave节点。

image

提高系统性能的原因在于:

  • 物理服务器增加,机器处理能力提升。拿硬件换性能。
  • 主从只负责各自的读和写,极大程度缓解X锁和S锁争用。
  • slave可以配置myiasm引擎,提升查询性能以及节约系统开销。
  • master直接写是并发的,slave通过主库发送来的binlog恢复数据是异步。
  • slave可以单独设置一些参数来提升其读的性能。
  • 增加冗余,提高可用性。

MySQL官方提供的数据库代理层产品MySQLProxy搭建读写分离。

MySQLProxy实际上是在客户端请求与MySQLServer之间建立了一个连接池。所有客户端请求都是发向MySQLProxy,然后经由MySQLProxy进行相应的分析,判断出是读操作还是写操作,分发至对应的MySQLServer上。对于多节点Slave集群,也可以起做到负载均衡的效果。

MySQL垂直分区

如果把业务切割得足够独立,那把不同业务的数据放到不同的数据库服务器将是一个不错的方案,而且万一其中一个业务崩溃了也不会影响其他业务的正常进行,并且也起到了负载分流的作用,大大提升了数据库的吞吐能力。经过垂直分区后的数据库架构图如下:

image

尽管业务之间已经足够独立了,但是有些业务之间或多或少总会有点联系,如用户,基本上都会和每个业务相关联,况且这种分区方式,也不能解决单张表数据量暴涨的问题。

MySQL水平分片(Sharding)

这是一个非常好的思路,将用户按一定规则(按id哈希)分组,并把该组用户的数据存储到一个数据库分片中,即一个sharding,这样随着用户数量的增加,只要简单地配置一台服务器即可,原理图如下:

image