专栏首页服务端思维MySQL单表数据不要超过500万行:是经验数值,还是黄金铁律?

MySQL单表数据不要超过500万行:是经验数值,还是黄金铁律?

梁桂钊 | 作者

今天,探讨一个有趣的话题:MySQL 单表数据达到多少时才需要考虑分库分表?有人说 2000 万行,也有人说 500 万行。那么,你觉得这个数值多少才合适呢?

曾经在中国互联网技术圈广为流传着这么一个说法:MySQL 单表数据量大于 2000 万行,性能会明显下降。事实上,这个传闻据说最早起源于百度。具体情况大概是这样的,当年的 DBA 测试 MySQL性能时发现,当单表的量在 2000 万行量级的时候,SQL 操作的性能急剧下降,因此,结论由此而来。然后又据说百度的工程师流动到业界的其它公司,也带去了这个信息,所以,就在业界流传开这么一个说法。

再后来,阿里巴巴《Java 开发手册》提出单表行数超过 500 万行或者单表容量超过 2GB,才推荐进行分库分表。对此,有阿里的黄金铁律支撑,所以,很多人设计大数据存储时,多会以此为标准,进行分表操作。

那么,你觉得这个数值多少才合适呢?为什么不是 300 万行,或者是 800 万行,而是 500 万行?也许你会说这个可能就是阿里的最佳实战的数值吧?那么,问题又来了,这个数值是如何评估出来的呢?稍等片刻,请你小小思考一会儿。

事实上,这个数值和实际记录的条数无关,而与 MySQL 的配置以及机器的硬件有关。因为,MySQL 为了提高性能,会将表的索引装载到内存中。InnoDB buffer size 足够的情况下,其能完成全加载进内存,查询不会有问题。但是,当单表数据库到达某个量级的上限时,导致内存无法存储其索引,使得之后的 SQL 查询会产生磁盘 IO,从而导致性能下降。当然,这个还有具体的表结构的设计有关,最终导致的问题都是内存限制。这里,增加硬件配置,可能会带来立竿见影的性能提升哈。

那么,我对于分库分表的观点是,需要结合实际需求,不宜过度设计,在项目一开始不采用分库与分表设计,而是随着业务的增长,在无法继续优化的情况下,再考虑分库与分表提高系统的性能。对此,阿里巴巴《Java 开发手册》补充到:如果预计三年后的数据量根本达不到这个级别,请不要在创建表时就分库分表。那么,回到一开始的问题,你觉得这个数值多少才合适呢?我的建议是,根据自身的机器的情况综合评估,如果心里没有标准,那么暂时以 500 万行作为一个统一的标准,相对而言算是一个比较折中的数值。

本文分享自微信公众号 - 服务端思维(gh_c3775931ac9d),作者:梁桂钊

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-06-19

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Flyway 助力数据库脚本自动化管理攻略

    今天,探讨一个有趣的话题:我们可以通过 Git 来实现项目版本控制;通过 Jenkins 进行持续集成,那么对于数据库层面,我们仍然依赖于纯手工运行 SQL 脚...

    用户2781897
  • 一个大学生做网页起家,靠“找你妹”验证码,获利500万!

    镁客网
  • 区块链技术公司谈支付巨头Visa的区块链支付

    Visa 将于2019年第一季度为企业支付推出自己的区块链服务。平台允许企业间跨境支付,该公司正与 IBM 合作,整合后者开发的开源 超级账本(Hyperled...

    用户3031714
  • 数据架构:概念与冷热分离

    关于架构,大家都有了解和理解。通常一个业务或项目,在做架构设计时,可能会包含业务架构和技术架构。其中技术架构是我们作为开发角色,在做设计时重点的工作内容。但还有...

    程序员架构进阶
  • 数据架构:概念与冷热分离

    关于架构,大家都有了解和理解。通常一个业务或项目,在做架构设计时,可能会包含业务架构和技术架构。其中技术架构是我们作为开发角色,在做设计时重点的工作内容。但还有...

    程序员架构进阶
  • “区块链苏九条”、广州黄埔“区块链十条”

    区块链大本营
  • 从《欢乐颂》五美开讲,在京城如何选房?

    《欢乐颂2》大结局的火锅餐已吃完,但围绕“五美”的话题热度却未减,YY《欢乐颂3》的群众更是乐此不疲。虽然俘获亿万富豪帅总裁、邂逅不羁摇滚小青年的剧情有些遥远...

    腾讯位置服务
  • “爬虫”程序吃掉低价机票 高科技“黄牛”怎么破?

    央广网北京12月27日消息(记者赵珂)据经济之声《天下公司》报道,2018年的春节已经离我们不远了。有消费者反映,自己希望能抢到一张回家的低价机票,但却在网上看...

    企鹅号小编
  • 数据爬取、清洗到分析,如何徒手研究上海二手房房价

    本文由作者:孙培培 原创投稿 声明:本文所公布代码及数据仅作学习用,若别有用途则后果自行承担。 提到上海,不得不提上海的高房价,最近一篇上海各市辖区均价的文章...

    机器学习AI算法工程

扫码关注云+社区

领取腾讯云代金券