码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 第三章:什么是分库分表


    文章目录

    • 背景
    • 什么是分库分表
    • 为什么要分库分表
      • 性能
      • 可用性
    • 什么时候考虑分库分表
      • 什么时候分库
      • 什么时候分表

    背景

    一个系统当伴随着用户量的激增,业务数据的不断增加,数据库表中的数据越来越多,如果再去对我们数据库中的表进行curd操作的时候,就会造成一些性能上的瓶颈问题!
    这就引入了我们今天话题,分库分表

    什么是分库分表

    我们就从他的字面意思来理解,这样有助于我们对分库分表有一个清晰的了解

    分库:他就是将我们原来用于存放单个数据库中的数据,进行拆分,将它存储到多个数据库中

    分表:他就是将我们原来存放在单个表中的数据,进行拆分,将它存储到多张表中

    为什么要分库分表

    分库分表自然是为了提升软件系统的性能以及增加其可用性

    性能

    随着系统上线的时间越久,数据量就会越大,我们查询的QPS也会越来越高的,那么相对应的读写时间也会增加。这样就导致了我们数据库读写的瓶颈期。从而考虑对数据库性能方面的优化。

    可用性

    我们都知道单体数据库如果发生了意外情况,就会导致我们数据的丢失。我们常规的保证可用行使用的是MS或者MM等等部署方式来解决可用性的问题。其实,我们对数据进行拆分也会提高容灾及可用性。

    什么时候考虑分库分表

    什么时候分库

    当我们的业务量持续增大的时候,多个服务在共享一个单体数据库的时候,数据库就会遇到性能瓶颈,这个时候就需要考虑分库。比如订单和用户等,都可以抽取出来,然后在搞个应用(其实就是微服务思想),并且拆分数据库(订单库、用户库)。
    数据库被切分以后后,就不能再依赖数据库自身的主键生成机制,最简单的可以考虑UUID(不连续,性能不佳),或者使用雪花算法来生成分布式ID(推荐使用)。

    什么时候分表

    当我们的系统处于快速发展的时期,如果每天订单的流水都新增几十万,并且,订单表的查询效率明显变慢的时候,就需要考虑进行规划分库分表了。一般B+树索引高度是2~3层最佳,当数据量达到千万级别,可能高度就变4层了,查询就会明显变慢了。不过业界流传,一般500万数据就开始要考虑分表了。

    欢迎大家点击下方卡片,关注《coder练习生》

  • 相关阅读:
    基于springboot+vue的戒毒所人员管理系统毕业设计源码251514
    DOM及DOM相关操作
    四、Vue3基础四
    什么是BI报表?
    Git相关: 拉取、git push提交 过程遇到的错误
    计算机毕业设计 基于协同过滤算法的白酒销售系统的设计与实现 Javaweb项目 Java实战项目 前后端分离 文档报告 代码讲解 安装调试
    Leetcode 112. 路径总和 java解决给定一个值判断二叉树根节点到叶子节点总和是否相等 算法
    Sonic云真机学习总结6 - 1.4.1服务端、agent端部署
    以太坊合并后,区块链生态将发生什么改变?
    基于时间的盲注
  • 原文地址:https://blog.csdn.net/ybb_ymm/article/details/130910751
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号