MySQL数据库碎片化:隐患与解决策略

为什么我们经常说不建议使用简单的 UUID 做 ID,当唯一索引,其实很大原因就是因为不规则的 UUID 会导致存储碎片,接下来聊一聊 MySQL 为什么会有存储碎片,影响大不大。关于 UUID 做主键还是自增主键,可参考往期文章:

被追着问 UUID 和自增 ID 做主键哪个好,为什么?

MySQL 中的数据库表常会出现物理存储碎片,特别是在频繁执行插入、删除和更新操作的情况下。这些操作会导致数据页中部分空间未被有效利用,或者导致数据在物理存储上排列不连续,进而形成碎片。

碎片的主要来源包括频繁的 DML 操作,如插入(insert)、更新(update)、删除(delete)。此外,使用可变长度字段(如 varchar 或 text)存储数据时,如果更新导致字段长度变化,也可能产生碎片问题。

insert 导致的碎片

我们都了解,InnoDB 使用 B+树索引结构来组织数据,通常按主键顺序存储。然而,当主键不是顺序自增的情况下,比如使用 UUID,新插入的数据行可能会引发页分裂现象。

页分裂会导致数据分散存储在磁盘的不同位置。新创建的页可能与原始页在物理存储上相隔甚远,导致数据在物理层面上不再连续,从而形成碎片。

页分裂通常发生在向 B+树索引插入新数据时,如果目标页已满,数据库系统就需要为新数据腾出空间。

那究竟什么是 InnoDB 的页分裂和页合并呢,mark 一下。下一篇出。

update 导致的碎片

除了插入操作可能导致碎片外,更新操作同样会产生碎片。特别是当更新操作导致数据行大小增加时,如果原始位置周围没有足够的空间容纳更新后的行,数据库可能会将这行数据移动到数据文件的其他位置。这种情况会留下原始位置的空闲空间,导致碎片的产生。

delete 导致的碎片

最容易导致碎片的操作实际上是 delete 操作,尤其在 InnoDB 中更为明显。执行 delete 后,InnoDB 仅仅是对数据行做了标记,而不是立即释放相应的空间。这样就可能导致数据页中存在大量未被使用的空间,增加了数据在物理存储上的分散程度,从而产生了碎片。

碎片的危害

表的碎片增多会导致数据在物理磁盘上存储变得不连续,从而使得数据库在查询数据时需要进行更多的磁盘 I/O 操作,进而降低查询效率。

此外,碎片化会导致数据库实际占用的存储空间比数据实际需要的空间大,造成磁盘空间的浪费,并可能影响缓存效率。

碎片化的数据还会增加备份文件的大小,同时使得备份和恢复的过程变得更为缓慢,因为这些操作也受到物理读写速度的影响。

因此,我们应该尽可能地减少碎片的产生,以提升数据库的性能和效率。

如何避免碎片

  1. 使用连续自增的 ID 而不是 UUID,可以使新创建的对象在 B+树的末尾插入,从而减少页分裂的可能性。
  2. 对于固定长度的字符串,应该优先选择 char 而不是 varchar,以减少存储碎片的发生。
  3. 避免在高度变动的列上创建索引,因为这可能会频繁触发页分裂。
  4. 使用 OPTIMIZE TABLE 命令可以重新组织表和索引的物理存储,有效减少碎片并优化表的存储和访问速度。

如有问题,欢迎微信搜索【码上遇见你】。

免费的Chat GPT可微信搜索【AI贝塔】进行体验,无限使用。

好了,本章节到此告一段落。希望对你有所帮助,祝学习顺利。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/41087.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

coco dataset标签数据结构(json文件)

COCO数据集现在有3种标注类型:object instances(目标实例), object keypoints(目标上的关键点), 和image captions(看图说话),使用json文件存储。 NameImagesLabelstrain linkhttp:…

Golang基础问题

Go基础 文章目录 Go基础● Go有那些关键字?● Go方法与函数的区别?● Go函数返回局部变量的指针是否安全?● Go函数参数传递是值传递还是引用传递?● defer关键字的实现原理?● 内置函数make和new的区别?●…

Yarn的安装方法

Yarn是由Facebook开发的一款快速、可靠、安全的JavaScript包管理工具,它是npm的替代品,提供了更快速的安装速度和更稳定的依赖版本管理。Yarn的安装与配置主要包括以下几个步骤: 一、安装Yarn Yarn的安装方法多种多样,以下是几种…

SVM的代码实现

生成假数据集:创建一个简单的二分类数据集。数据标准化:标准化特征。定义线性核函数:选择一个简单的线性核。定义优化问题:使用对偶问题进行求解。求解对偶问题:通过简单的梯度上升法求解对偶问题。确定支持向量&#…

kotlin协程的理解

伴生对象:companion object 其实质等同于Java中的单例模式 协程:通常实现是用户态的任务协作式调度 一段可执行代码可挂起/可恢复执行概念上与语言无关,协程这个概念于1958年提出 依赖框架: 协程的启动: 1.协程体&a…

大模型LLMs概述:利用大模型 (LLMs) 解决信息抽取任务

论文标题:Large Language Models for Generative Information Extraction: A Survey 论文链接:https://arxiv.org/pdf/2312.17617.pdf 论文主要探讨了大型语言模型(LLMs)在生成式信息抽取(IE)任务中的应用…

属性描述符初探——Vue实现数据劫持的基础

目录 属性描述符——Vue实现数据劫持的基础 一、属性描述符是什么? ​编辑 1.1、属性描述符示例 1.2、用属性描述符定义属性及获取对象的属性描述符 1.3、带有读取器和设置器的属性描述符 二、使用属性描述符的情景 2.1、封装和数据隐藏 使用getter和setter…

Desktop docker 部署 WordPress

Desktop Docker 部署 WordPress 之前都是在Linux里面玩的,今天看到别人在windwos下安装docker,一时兴起装了一个试试,效果一般,很吃硬盘空间和内存。 首先在docker官方下载桌面版,安装下一步一直到完成。 安装完docker会自动加入到环境变量,而且docker-compose也会一并安…

sql业务场景分析思路参考

1、时间可以进行排序,也可以用聚合函数对时间求最大值max(时间) 例如下面的例子:取最晚入职的人,那就是将入职时间倒序排序,然后limit 1 表: 场景:查找最晚入职员工的所有信息 se…

第十四届蓝桥杯省赛C++B组F题【岛屿个数】题解(AC)

题目大意 给定一个 01 地图,分别表示陆地和海,问地图中一共有多少块岛屿?另外,若一个岛屿在另一个岛屿的内部,则不统计。如下图中的大岛屿包含着内部的小岛屿,故内部小岛屿不计算,最终输出 1。…

vue3自定义全局指令和局部指令

1.全局指令 el:指令绑定到的DOM元素,可以用于直接操作当前元素,默认传入钩子的就是el参数,例如我们开始实现的focus指令,就是直接操作的元素DOM binding:这是一个对象,包含以下属性:…

oracle中的nocache的用法和例子

在Oracle数据库中,NOCACHE是与序列(Sequence)对象相关的一个选项,用于控制序列值的生成方式。当在创建或修改序列时指定NOCACHE选项,Oracle数据库将不会预先在内存中缓存序列值,而是每次调用序列的NEXTVAL时…

【C#】ProgressBar进度条异步编程思想

1.控件介绍 进度条通常用于显示代码的执行进程进度,在一些复杂功能交互体验时告知用户进程还在继续。 在属性栏中,有三个值常用: Value表示当前值,Minimum表示进度条范围下限,Maximum表示进度条范围上限。 2.简单实…

简单的git pull fail Can‘t update has no tracked branch解决记录

简单的git pull fail Can‘t update has no tracked branch解决记录 1. 问题描述 上午同事使用idea拉取代码的时候,发现拉取不了,提示用户权限问题,之后修改了git用户信息,发现还是拉取不了分支代码,然后删除了git r…

对FPGA开发流程系统的学习

FPGA 开发流程: HDL(Hardware Design Language)和原理图是两种最常用的数字硬件电路描述方法,HDL 设计法具有更好的可移植性、通用性和模块划分与重用性的特点,在目前的工程设计中被广泛使用。所以,我们在…

WPF在.NET9中的重大更新:Windows 11 主题

在2023年的2月20日,在WPF的讨论区,WPF团队对路线的优先级发起了一次讨论。 对三个事项发起了投票。 第一个是Windows 11 主题 第二个是更新的控件 第三个是可空性注释 最终Windows 11 主题得票最高,WPF团队2023-2024的工作优先级就是Windows…

网安小贴士(8)IPv4与IPv6

一、前言 IPv4和IPv6都是互联网协议(IP)的版本,它们用于在互联网上标识和定位设备。 二、定义 IPv4(互联网协议第四版): IPv4是互联网协议的第一个广泛使用的版本,最初在1981年被标准化为RFC 7…

利用Java构建高可靠性的分布式系统

利用Java构建高可靠性的分布式系统 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿! 1. 引言 随着互联网应用的发展和用户规模的增长,构建高可靠性…

交换数字00

题目链接 交换数字 题目描述 注意点 numbers.length 2-2147483647 < numbers[i] < 2147483647 解答思路 不适用临时变量&#xff0c;可以先将numbers[0]和numbers[1]的信息都存到某个位置&#xff08;可以相加可以相减或其他位操作&#xff09;&#xff0c;然后另一…

SpringBoot 通过Knife4j集成API文档 在线调试

介绍 Knife4j 是一款基于 Swagger 构建的增强型 API 文档生成工具&#xff0c;它提供了更多的定制化功能和界面优化&#xff0c;使得生成的 API 文档更加美观和易用。它可以帮助开发者快速生成和管理 API 文档&#xff0c;支持在线调试和交互。 依赖 <!--knife4j--> &…