前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL的容量规划

MySQL的容量规划

作者头像
MySQLSE
发布2023-11-22 14:00:41
1180
发布2023-11-22 14:00:41
举报

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

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

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

  • InnoDB的行和索引数据都保存在磁盘页中,页的默认大小为16KB。InnoDB表和索引由包含数据的叶页和包含页指针的非叶页组成。页面通常有空闲空间,因为InnoDB根据主键对数据行进行排序、InnoDB在同一页面上为每一数据行保留列,并且数据行不总是均匀地填充数据页。
  • 逻辑表的大小会小于物理文件的大小。因为逻辑大小仅包括数据和索引页,物理大小除了数据和索引还包括空页、页眉和页脚等信息。

如何计算逻辑大小?

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

代码语言:javascript
复制
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的表空间文件信息。例如,
代码语言:javascript
复制
mysql> SELECT FILE_NAME,TOTAL_EXTENTS * EXTENT_SIZE as `size`
-> FROM INFORMATION_SCHEMA.FILES
-> WHERE FILE_NAME LIKE '%emp1oyees%';

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

  • 读取文件系统

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

代码语言:javascript
复制
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表的逻辑大小和物理大小,为制定基线,容量规划提供可测量的数值。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-11-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 MySQL解决方案工程师 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档