MySQL的容量规划和了解途径

2023年 11月 21日 60.6k 0

通常我们可以从数据字典、物理文件等层面,了解到数据库用了多少空间、需要多少空间,以便于我们能对容量进行预估和监控。徐老师的这篇文章《MySQL的容量规划》讲解了在MySQL中了解容量的操作途径。

MySQL作为一款面向企业的数据库产品,必须具有能够处理高峰活动和数据容量增长的能力。在进行容量规划时,架构师需要考虑因为用户的活动和数据增长所导致的资源使用变化,并需要考虑未来的促销活动或者其他预计的繁忙时期。

当用户为系统增加资源时,注意一次不要增加太多的资源,增加过多的服务器或硬件是一种浪费,无法提供有价值的投资回报。用户可以在基线中确定关键元素,用以监视资源的变化,随着数据或者应用程序功能的增长,增加服务器的内存和磁盘空间。

在MySQL容量规划的过程中,非常关键的一点是监视表的容量。

  • InnoDB的行和索引数据都保存在磁盘页中,页的默认大小为16KB。InnoDB表和索引由包含数据的叶页和包含页指针的非叶页组成。页面通常有空闲空间,因为InnoDB根据主键对数据行进行排序、InnoDB在同一页面上为每一数据行保留列,并且数据行不总是均匀地填充数据页。

  • 逻辑表的大小会小于物理文件的大小。因为逻辑大小仅包括数据和索引页,物理大小除了数据和索引还包括空页、页眉和页脚等信息。

如何计算逻辑大小?

逻辑大小包括数据和索引,可以通过执行SQL语句从INFORMATION SCHEMA. TABLES”中获得。例如,

    mysql> SELECT TABLE NAME AS`table`,
    ->DATA LENGTH + INDEX_ LENGTH AS `logical size`
    ->FROM INFORMATION_SCHEMA.TABLES
    ->WHERE TABLE_SCHEMA='employees';

    如何计算物理大小?

    • 可以通过查询INFORMATION_SCHEMA.FILES视图获得InnoDB的表空间文件信息。例如,

      mysql> SELECT FILE_NAME,TOTAL_EXTENTS * EXTENT_SIZE as `size`
      -> FROM INFORMATION_SCHEMA.FILES
      -> WHERE FILE_NAME LIKE '%emp1oyees%';

      该方法适用于全部的表,如果表空间文件中包含多个表,则输出值为多个表的合计。

      • 读取文件系统

      查看包含表数据的.ibd文件,该方法适用于使用独立表空间文件的表。例如,

        ls -l *.ibd
        -rw-r-----. 1 root root 606208 11月 7 14:21 city.ibd
        -rw-r-----. 1 root root 196608 11月 7 14:21 country.ibd
        -rw-r-----. 1 root root 245760 11月 7 14:21 countrylanguage.ibd

        通过以上的方法,用户可以查看MySQL表的逻辑大小和物理大小,为制定基线,容量规划提供可测量的数值。

        如果您认为这篇文章有些帮助,还请不吝点下文章末尾的"点赞"和"在看",或者直接转发pyq,

        近期更新的文章:《Cache和Buffer两个名词相同不相同?》《MySQL备份和恢复的最佳实践》《应用运维的一些工作思路了解》《Oracle中truncate删除的数据还能找到?》《MySQL创建内部临时表的场景》
        近期的热文:《推荐一篇Oracle RAC Cache Fusion的经典论文》
        《"红警"游戏开源代码带给我们的震撼》
        文章分类和索引:《公众号1300篇文章分类和索引》

        相关文章

        Oracle如何使用授予和撤销权限的语法和示例
        Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
        下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
        社区版oceanbase安装
        Oracle 导出CSV工具-sqluldr2
        ETL数据集成丨快速将MySQL数据迁移至Doris数据库

        发布评论