mysql面试题16:说说分库与分表的设计?常用的分库分表中间件有哪些?分库分表可能遇到的问题有哪些?-LMLPHP

该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点

面试官:说说分库与分表的设计?

在MySQL中,分库与分表是常用的数据库水平扩展技术,可以提高数据库的吞吐量和扩展性。下面将具体讲解MySQL中分库与分表的设计。

  1. 分库设计:

    分库即将一个大的数据库拆分为多个小的数据库,每个数据库独立存储一部分数据。分库设计可以根据业务需求、数据量和负载情况来确定。

    • 垂直分库:按照功能或模块将不同的表分配到不同的数据库。
    • 水平分库:按照数据的某种规则(如范围、哈希等)将数据行分配到不同的数据库。

    在分库设计中,需要注意以下几点:

    • 跨库事务问题:跨库事务可能会带来一致性问题,需要使用分布式事务或其他解决方案来保证数据的一致性。
    • 全局唯一性问题:如果需要全局唯一的ID或其他标识符,可以使用分布式ID生成算法,如Snowflake算法。
    • 跨库查询问题:在涉及多个数据库的查询中,需要使用分布式查询工具或者在应用层进行数据整合。
  2. 分表设计:

    分表即将一个大的表拆分成多个小的表,每个表独立存储一部分数据。分表设计可以根据数据量、查询频率和负载情况来确定。

    • 垂直分表:按照功能或模块将不同的列分配到不同的表。
10-05 05:35