我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL之Innodb_buffer_pool_size设置方式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL之Innodb_buffer_pool_size设置方式

Innodb_buffer_pool_size设置方式

缓冲池是用于存储InnoDB表,索引和其他辅助缓冲区的缓存数据的内存区域。缓冲池的大小对于系统性能很重要。更大的缓冲池可以减少磁盘I/O来多次访问同一表数据。在专用数据库服务器上,可以将缓冲池大小设置为计算机物理内存大小的80%

缓冲池相关参数说明

1)系统变量参数

  • Innodb_page_size
  • InnoDB页面大小(默认为16KB)。页面中包含许多值,页面大小使它们可以轻松转换为字节。
  • Innodb_buffer_pool_chunk_size
  • innodb_buffer_pool_chunk_size 定义InnoDB缓冲池大小调整操作的块大小。默认128M。最大值可设置innodb_buffer_pool_size / innodb_buffer_pool_instances
  • innodb_buffer_pool_instances
  • InnoDB 缓冲池划分为的区域数。
  • Innodb_buffer_pool_pages_data
  • 数页在 InnoDB 缓冲池中包含的数据。该数字包括 脏页和干净页。使用压缩表时,报告的 Innodb_buffer_pool_pages_data 值可能大于 Innodb_buffer_pool_pages_total (错误#59550)。
  • Innodb_buffer_pool_pages_total
  • InnoDB 缓冲池 的总大小(以页为单位)。使用压缩表时,报告的 Innodb_buffer_pool_pages_data 值可能大于 Innodb_buffer_pool_pages_total (错误#59550)

2)运行状态变量

  • Innodb_buffer_pool_pages_flushed
  • 从缓冲池刷新页面的请求数 。
  • Innodb_buffer_pool_read_requests
  • 表示从内存中读取逻辑的请求数。
  • Innodb_buffer_pool_reads
  • InnoDB 不能从缓冲池满足的逻辑读取的数量,必须直接从磁盘读取。
  • Innodb_buffer_pool_wait_free
  • 通常,对InnoDB缓冲池的写入是在后台进行的。当InnoDB需要读取或创建一个页面而没有可用的干净页面时,InnoDB会首先刷新一些脏页面并等待该操作完成。此计数器统计这些等待的实例。如果innodb_ buffer_pool_size设置正确,这个值应该很小。

合理的设置缓存池相关参数

1、innodb_buffer_pool_size 默认设置系统内存百分之80%,后按如下规则配合实际情况调整

mysql> show global status like 'Innodb_buffer_pool_pages_data';
+-------------------------------+---------+
| Variable_name                 | Value   |
+-------------------------------+---------+
| Innodb_buffer_pool_pages_data | 1894874 |
+-------------------------------+---------+
1 row in set (0.00 sec)

mysql>  show global status like 'Innodb_buffer_pool_pages_total';
+--------------------------------+---------+
| Variable_name                  | Value   |
+--------------------------------+---------+
| Innodb_buffer_pool_pages_total | 1965960 |
+--------------------------------+---------+
1 row in set (0.00 sec)

# 计算是否应该添加内存
使用率 = Innodb_buffer_pool_pages_data/Innodb_buffer_pool_pages_total*100%
当结果 > 95% 则增加 innodb_buffer_pool_size
当结果 < 95% 则减少 innodb_buffer_pool_size, 可适当较少,当然独享业务机器多了也没啥问题

2、innodb_buffer_pool_instances 默认设置为8,最小1,最大64

对于缓冲池在数千兆字节范围内的系统,通过减少争用不同线程读写缓存页面的争用,将缓冲池划分为多个单独的实例可以提高并发性。此功能通常用于缓冲池大小在数GB范围内的系统。使用innodb_buffer_pool_instances 配置选项配置了多个缓冲池实例 ,您也可以调整该innodb_buffer_pool_size值。

当InnoDB缓冲池很大时,可以通过从内存中检索来满足许多数据请求。您可能会遇到多个线程试图立即访问缓冲池的瓶颈。您可以启用多个缓冲池以最小化此争用。使用散列函数,将存储在缓冲池中或从缓冲池中读取的每个页面随机分配给其中一个缓冲池。每个缓冲池管理自己的空闲列表,刷新列表,LRU和连接到缓冲池的所有其他数据结构,并受其自己的缓冲池互斥量保护。

要启用多个缓冲池实例,请将innodb_buffer_pool_instances配置选项设置为 大于1(默认)的值,最大为64(最大)。仅当您将innodb_buffer_pool_size大小设置为1GB或更大时,此选项才生效 。您指定的总大小将分配给所有缓冲池。为了获得最佳效率,指定的组合 innodb_buffer_pool_instances 和innodb_buffer_pool_size,使得每个缓冲池实例是至少为1GB。

总结:

# cat /etc/my.cnf
[mysqld]
......
innodb_buffer_pool_size = 系统内存%80
innodb_buffer_pool_instances = 大于8的情况下,每个缓冲池实例至少1GB
......

Reference:

  • https://dev.mysql.com/doc/refman/5.7/en/innodb-parameters.html
  • https://dev.mysql.com/doc/refman/5.7/en/server-status-variables.htm
  • https://dev.mysql.com/doc/refman/5.7/en/innodb-buffer-pool-resize.html

设置innodb_buffer_pool_size参数

用于缓存索引和数据的内存大小,这个当然是越多越好, 数据读写在内存中非常快, 减少了对磁盘的读写。

当数据提交或满足检查点条件后才一次性将内存数据刷新到磁盘中。

然而内存还有操作系统或数据库其他进程使用, 根据经验,推荐设置innodb-buffer-pool-size为服务器总可用内存的75%。 若设置不当, 内存使用可能浪费或者使用过多。

对于繁忙的服务器, buffer pool 将划分为多个实例以提高系统并发性, 减少线程间读写缓存的争用。buffer pool 的大小首先受 innodb_buffer_pool_instances 影响, 当然影响较小。

1.Innodb_buffer_pool_pages_data: Innodb buffer pool缓存池中包含数据的页的数目,包括脏页。单位是page。

show global status like 'Innodb_buffer_pool_pages_data';

2.Innodb_buffer_pool_pages_total: innodb buffer pool的页总数目。单位是page。

show global status like 'Innodb_buffer_pool_pages_total';

3.show global status like 'Innodb_page_size'; 查看@@innodb_buffer_pool_size大小,单位字节

SELECT @@innodb_buffer_pool_size/1024/1024/1024; #字节转为G

4.在线调整InnoDB缓冲池大小,如果不设置,默认为128M

set global innodb_buffer_pool_size = 4227858432; ##单位字节

计算Innodb_buffer_pool_pages_data/Innodb_buffer_pool_pages_total*100%

  • 当结果 > 95% 则增加 innodb_buffer_pool_size, 建议使用物理内存的 75%
  • 当结果 < 95% 则减少 innodb_buffer_pool_size, 建议设置大小为: Innodb_buffer_pool_pages_data * Innodb_page_size * 1.05 / (1024*1024*1024)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL之Innodb_buffer_pool_size设置方式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql外键设置方式是什么

这篇文章给大家介绍mysql外键设置方式是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。外键的作用保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值!例如:a
2023-06-22

Mysql中的超时时间设置方式

这篇文章详细阐述了MySQL中超时时间设置方式,包括连接超时、查询超时和数据发送/接收超时。通过正确设置这些超时值,可以防止资源浪费并提高数据库性能。最佳实践包括合理设置连接超时、根据查询复杂性优化查询超时,并针对不同网络负载调整数据发送/接收超时。此外,文章提供了故障排除建议和说明了会话级和全局级超时设置以及其他注意事项。
Mysql中的超时时间设置方式
2024-04-02

mysql用户管理和权限设置方式

目录mysql用户管理和权限设置MYSQL到底都有哪些权限呢?MySQL权限经验原则MySQL权限实战1. 创建用户2. 授权3. 设置与更改用户密码4. 撤销用户权限5. 删除用户总结mysql用户管理和权限设置MYSQL到底都有哪些权
mysql用户管理和权限设置方式
2024-08-09

mysql设置编码格式-

创建table的时候就使用utf8编码在每次创建表的时候都在最后加上 character set = utf8就可以很好的支持中文 create table xxx ( id int auto_increment, t
mysql设置编码格式-
2019-01-10

django之用户、用户组及权限设置方式

目录一,django中超级用户与普通用户的本质区别1,当使用命令python manage.py createsuperuser后2,使用命令创建普通用户后3,使用authenticate对所有用户进行认证二,模型的默认权限1,在后台查看权
2023-05-12

MySQL数据库远程访问权限设置方式

目录mysql数据库远程访问权限设置改表(当然我们要先知道表在哪,适用于整个数据库)1、直接修改2、加指定用户以及指定权限授权总结MySQL数据库远程访问权限设置对于初学者小伙伴来说,我们安装mysql到本地服务,再用一些图形化工具链接。
2023-04-27

编程热搜

目录