Mysql分片,大数据量时扩容解决方案

 更新时间:2024年06月01日 15:21:03   作者:FYHannnnnn  
这篇文章主要介绍了Mysql分片,大数据量时扩容解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

分片概念

分片(Sharding)就是用来确定数据在多台存储设备上分布的技术。

Shard这个词的意思是“碎片”,如 果将一个数据库当作一块大玻璃,将这块玻璃打碎,那么每一小块都称为数据库的碎片(Database Sharding)。

将一个数据库打碎成多个的过程就叫做分片,分片是属于横向扩展方案。

分片与分表的区别

分片:表示分配过程,是一个逻辑上概念,表示如何实现。

分库分表:表示分配结果,是一个物理上概念,表示最终实现的结果

分片策略

基于范围分片

根据特定的字段进行拆分,比如ID0-100到 Cluster A节点中,100-200的到Cluster B节点中...

  • 优点:新的数据可以落在新的存储节点上,如果集群扩容,数据无需迁移。
  • 缺点:热点数据分部不均匀则会导致机器负荷程度的不均匀,会浪费资源也会导致部分机器过载。

哈希取模分片(离散分片)

根据Hash算法取模对应一些机器编号进行入库。

  • 优点:数据分配比较均匀,不容易出现冷热不均,负荷不均的情况。
  • 缺点:比较均匀,但是在扩容时会产生大量的数据迁移(因为Hash算法取模要整体重新计算),比如从n台设备扩容到n+1,绝大部分数据需要重新分配和 迁移。

一致性哈希分片

相比较传统的Hash算法,通过环的方式在添加节点(扩容)或者删除节点时,只对增加节点的单个环上进行添加,则无须进行大面积的数据迁移。

在数据库容量有限的情况下,分片,分库,分表也会达到瓶颈,而这时候的扩容方式则需要去横向增加节点扩容处理。

一,初期方案(停机扩容)

停机扩容,关闭服务不符合现阶段高可用的价值观,并且如果有问题没有及时测试出来启动了服务,运行后发现问题,数据会丢失一部分,难以回滚。

该方案虽然简单但只适合小型网站或者对高可用要求不高的程序,或是测试上线阶段。

二,平滑扩容(上线运行之后)

平滑扩容也称之为成倍扩容,例如从两个节点扩到四个节点,通过双主配置双写进行数据同步。

双主双写之后进行同步,在可容忍的延迟下,保证数据的同步完成。

(因为高可用要求高的程序下,随时都会存在写的数据录入,所以会有延迟情况)

同步完成后,则取消掉双主同步,重启即可。

平滑扩容虽然做到了高可用的要求,但是配置程序很复杂、配置双主同步、双主双写、检测数据同步等,且后期数据库扩容,因为是成倍扩容,代价会不断变大。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL 给用户添加 ALTER VIEW 的权限的步骤

    MySQL 给用户添加 ALTER VIEW 的权限的步骤

    在 MySQL 中,用户权限的管理是非常重要的,以确保数据库安全性和数据完整性,这篇文章主要介绍了MySQL 给用户添加 ALTER VIEW 的权限,需要的朋友可以参考下
    2024-05-05
  • MySQL由浅入深掌握连接查询

    MySQL由浅入深掌握连接查询

    连接查询是关系数据库中最主要的查询,主要包括内连接、外连接和交叉连接等。通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志
    2022-03-03
  • ubuntu下设置mysql自动备份的例子

    ubuntu下设置mysql自动备份的例子

    ubuntu下设置mysql自动备份的例子,供大家学习参考
    2013-01-01
  • MySQL中的唯一索引的简单学习教程

    MySQL中的唯一索引的简单学习教程

    这篇文章主要介绍了MySQL中的唯一索引的简单学习教程,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-11-11
  • C#编写方法实例

    C#编写方法实例

    在下面的练习中,将创建一个应用程序,它包含的一个方法能够计算一名顾问的收费金额——假定该顾问每天收取固定的费用,将根据工作了多少天来收费。首先要开发应用程序的逻辑,然后利用“生成方法存根向导”来写出这个逻辑使用的方法。接着,我们将在一个控制台应用程序中运行方法,以获得对该程序的最终印象。最后,我们将使用Visual Studio 2005调试器来检查方法调用。
    2008-04-04
  • mysql索引使用技巧及注意事项

    mysql索引使用技巧及注意事项

    本篇文章主要介绍了mysql索引使用技巧及注意事项,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • 一个字段同时满足多个条件的查询

    一个字段同时满足多个条件的查询

    当一个字段需要同时等于多个值的时候,用and直接连不会有数据查出。
    2011-08-08
  • SQL实现LeetCode(196.删除重复邮箱)

    SQL实现LeetCode(196.删除重复邮箱)

    这篇文章主要介绍了SQL实现LeetCode(196.删除重复邮箱),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 详解Navicat远程连接mysql很慢

    详解Navicat远程连接mysql很慢

    这篇文章主要介绍了详解Navicat远程连接mysql很慢(以及数据库连接报错"Too many connections")解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • CentOS mysql安装系统方法

    CentOS mysql安装系统方法

    CentOS mysql安装还是很常用的软件,我就学习如何CentOS mysql安装,在这里拿出来和大家分享一下,希望对大家有用。
    2010-11-11

最新评论