雪花ID和UUID自增主键做 MySQL主键
创作时间:
作者:
@小白创作中心
雪花ID和UUID自增主键做 MySQL主键
引用
1
来源
1.
https://www.cnblogs.com/KL2016/p/18798004
使用uuid和自增id的索引结构对比.
使用自增id的内部结构
自增的主键的值是顺序的,所以Innodb把每一条记录都存储在一条记录的后面。当达到页面的最大填充因子时候(innodb默认的最大填充因子是页大小的15/16,会留出1/16的空间留作以后的 修改):
- 下一条记录就会写入新的页中,一旦数据按照这种顺序的方式加载,主键页就会近乎于顺序的记录填满,提升了页面的最大填充率,不会有页的浪费
- 新插入的行一定会在原有的最大数据行下一行,mysql定位和寻址很快,不会为计算新行的位置而做出额外的消耗
- 减少了页分裂和碎片的产生
使用uuid的索引内部结构
因为uuid相对顺序的自增id来说是毫无规律可言的,新行的值不一定要比之前的主键的值要大,所以innodb无法做到总是把新行插入到索引的最后,而是需要为新行寻找新的合适的位置从而来分配新的空间。这个过程需要做很多额外的操作,数据的毫无顺序会导致数据分布散乱,将会导致以下的问题:
- 写入的目标页很可能已经刷新到磁盘上并且从缓存上移除,或者还没有被加载到缓存中,innodb在插入之前不得不先找到并从磁盘读取目标页到内存中,这将导致大量的随机IO。
- 因为写入是乱序的,innodb不得不频繁的做页分裂操作,以便为新的行分配空间,页分裂导致移动大量的数据,一次插入最少需要修改三个页以上
- 由于频繁的页分裂,页会变得稀疏并被不规则的填充,最终会导致数据会有碎片
使用自增id的缺点
- 别人一旦爬取你的数据库,就可以根据数据库的自增id获取到你的业务增长信息,很容易分析出你的经营情况
- 对于高并发的负载,innodb在按主键进行插入的时候会造成明显的锁争用,主键的上界会成为争抢的热点,因为所有的插入都发生在这里,并发插入会导致间隙锁竞争
- Auto_Increment锁机制会造成自增锁的抢夺,有一定的性能损失
热门推荐
复旦团队牵头的“中风醒脑方”疗效临床研究发表于《柳叶刀》
三分之一的美国人新陈代谢紊乱,但间歇性禁食可能会有所帮助
院子里适合种植哪些类型的植物?
沈阳跃居东北人口增量第一城,浑南区成最年轻城区
日本娱乐和夜生活
国有大行出手!中国银行上调积存金起购点至700元 为开年金价创新高后首家跟进
中国温泉:利用互联网,开启新天地
李安导演生涯十大经典电影回顾
无氧运动包括哪些
中国古代建筑常见的形式
装修技巧之基装包括哪些?
口水弄在皮肤上为什么会有臭味?
10种高铁蔬果一次看,缺铁不用狂吃肉!维生素C助攻,补铁更高效
感冒后身体虚弱无力怎么快速恢复
数据库中BCNF(Boyce-Codd范式)详解
体检前一天感冒了,怎么办?
看,这就是2035年的广州花都① | 规划解读——北部增长极这样建
流程优化与再造的主要工具和方法有哪些?
10种现代诗表现手法,写出打动人心的诗歌!
探秘“欧”的多重含义与文化内涵
生活饮用水总β放射性检测
一审败诉后:上诉还是申诉快?
缺斤少两:如何收集证据来维护自己的权益
姜子牙这6句智慧名言,条条精辟,尽显处世大谋略!
电动三轮车上牌指南:条件、材料及注意事项全解析
CameraX使用详解:从入门到实战
如何驱逐暴走团队
烧酒会是日本的明日之星吗?适合所有人的酒精饮料
蜂胶提取物可显著抑制晚期糖基化终末产物和蛋白质氧化
蜂胶的副作用是什么