雪花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锁机制会造成自增锁的抢夺,有一定的性能损失
热门推荐
郭鹤年:从“糖王”到“酒店大王”的商业巨擘
冬季类风湿饮食调理:从生姜到当归羊肉汤
类风湿关节炎无法根治?这些方法可控制病情
柴胡疏肝丸配合情志相胜法,中医调理肝气不舒有良方
七夕理财秘籍:情侣共同理财的五大原则
张伟教你恋爱消费分摊秘籍
整形医生详解:科学应对眼袋问题,从日常护理到专业治疗
员工被追缴佣金!恒大财富最新进展
QQ账号被盗,你第一时间该做什么?
文殊菩萨雕像背后的秘密
品牌年轻化转型:如何与年轻消费群体共鸣?
职场人必备:情绪价值与情商的双重修炼之道
正确使用盐酸丁螺环酮片,专家详解用药注意事项
盐酸丁螺环酮片治焦虑,医生建议这样安全用药
抗焦虑药盐酸丁螺酮片:作用机制与使用注意事项
巴黎圣母院历经五年修复重现辉煌,现代科技助力传统工艺
中法携手修复巴黎圣母院,3D建模重现哥特式建筑原貌
巴黎圣母院修复完成:中国技术助力重现哥特式建筑辉煌
榫卯、壁画修复显身手,中国工艺助力巴黎圣母院重生
中国技术助力巴黎圣母院重生,中法文化遗产合作迈新步
中法合作修复巴黎圣母院,中国3D技术重现建筑原貌
人类对外星生命探索有新发现?或许离真相不远,但为何还找不到?
迄今为止,人类发现的五个,所谓外星生命的存在证据
甘草酸二铵治脂肪肝效果好,但需遵医嘱使用
0-6个月宝宝头型护理全攻略:从睡姿到环境布置
2型糖尿病预防秘籍:从高危人群到健康生活
华为手机异常震动?教你快速排查
哈佛36年研究:染发剂增加多种癌症风险,对苯二胺是关键因素
从标签到群聊:微信客户管理的五个实用技巧
染发伤头皮?天然成分和科学护理帮你规避风险