返回顶部
首页 > 资讯 > 数据库 >MySQL数据库InnoDB存储引擎的 UNDO空间调整步骤的专题报告
  • 817
分享到

MySQL数据库InnoDB存储引擎的 UNDO空间调整步骤的专题报告

2024-04-02 19:04:59 817人浏览 独家记忆
摘要

专题描述对已经运行的Mysql数据库InnoDB存储引擎的配置参数innodb_log_file_size大小或文件组个数调整,需要遵循的标准化步骤。解决方案1修改参数,使mysql下次关闭时进行clean

专题描述对已经运行的Mysql数据库InnoDB存储引擎的配置参数innodb_log_file_size大小或文件组个数调整,需要遵循的标准化步骤。
解决方案1修改参数,使mysql下次关闭时进行clean shutdown。
set global innodb_fast_shutdown=0;
(官方文档并无此项建议,但是安全起见,推荐进行clean shutdown,使Mysql将所有修改写入数据文件,摆脱对innodb_log_file的依赖,此参数若设置为2,当数据库突然关闭时,系统将立即刷事务日志到磁盘上并且冷关闭mysqld服务;没有提交的事务将会丢失,但是再启动mysqld服务的时候会进行事务回滚恢复;)。
clean shutdown含义为将脏页数据刷回磁盘保存。
2停止应用系统。(必要时,应当在数据库端杀掉所有数据库连接)
3等待InnoDB脏页刷出。
4观察show global status like 'Innodb_buffer_pool_pages_dirty';的返回结果,直至结果接近0。
如果这一步骤耗时超出可接受范围,此时可以随时中止操作,恢复应用。

5关闭MySQL数据库,关闭期间数据库因为需要将内存缓冲池中数据刷回磁盘保存,可能存在大量随机读取io
这次关闭需要较久的时间,需要耐心等待。
6检查错误日志,确认没有可疑报错信息。
7编辑配置文件中的innodb_log_file_size参数。
8启动数据库,系统将根据新设定的innodb_log_file_size值修改事务日志文件大小,检查数据库是否运行正常。
9预热数据库即将部分数据缓存到内存缓冲池中,减少应用启动时对于磁盘的IO冲击(可选)。
10启动应用,重新连接数据库。
知识点1如果InnoDB检查到innodb_log_file_size和redo log文件数量不相等,InnoDB将写入一个日志检查点,关闭和移动旧的日志文件,
创建一个要求大小的新日志文件并打开它。
2innodb_fast_shutdown: 
含义:设置innoDB引擎关闭的方式,默认值为:1,正常关闭的状态; 
0 — mysqld服务关闭前,先进行数据完全的清理和插入缓冲区的合并操作,若是脏页数据 
较多或者服务器IO性能等因素,会导致此过程需要数分钟或者更长时间; 
1 — 正常关闭mysqld服务,针对innodb引擎不做任何其他的操作; 
2 — 若是mysqld出现崩溃,立即刷事务日志到磁盘上并且冷关闭mysqld服务;没有提交 
的事务将会丢失,但是再启动mysqld服务的时候会进行事务回滚恢复; 
3Innodb_buffer_pool_pages_dirty:
含义:InnoDB内存缓冲池中脏页的比例。关闭数据库时该参数等于0,说明脏页刷回磁盘。
4脏页数据计算公式:脏页数据大小=Innodb_buffer_pool_pages_dirty*Innodb_buffer_pool_size。
5innodb_log_file_size:
含义:事务日志的大小


您可能感兴趣的文档:

--结束END--

本文标题: MySQL数据库InnoDB存储引擎的 UNDO空间调整步骤的专题报告

本文链接: https://lsjlt.com/news/40098.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作