专题描述 | 对已经运行的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将写入一个日志检查点,关闭和移动旧的日志文件, 创建一个要求大小的新日志文件并打开它。 | |||
2 | innodb_fast_shutdown: 含义:设置innoDB引擎关闭的方式,默认值为:1,正常关闭的状态; 0 — mysqld服务关闭前,先进行数据完全的清理和插入缓冲区的合并操作,若是脏页数据 较多或者服务器IO性能等因素,会导致此过程需要数分钟或者更长时间; 1 — 正常关闭mysqld服务,针对innodb引擎不做任何其他的操作; 2 — 若是mysqld出现崩溃,立即刷事务日志到磁盘上并且冷关闭mysqld服务;没有提交 的事务将会丢失,但是再启动mysqld服务的时候会进行事务回滚恢复; | ||||
3 | Innodb_buffer_pool_pages_dirty: 含义:InnoDB内存缓冲池中脏页的比例。关闭数据库时该参数等于0,说明脏页刷回磁盘。 | ||||
4 | 脏页数据计算公式:脏页数据大小=Innodb_buffer_pool_pages_dirty*Innodb_buffer_pool_size。 | ||||
5 | innodb_log_file_size: 含义:事务日志的大小 |