分类: Mysql/postgreSQL
2015-05-05 16:14:48
故障现象:在数据库重启后,碰巧遇到业务高峰期,连接数满,导致用户登录一直等待,此时数据库处于无响应状态.
故障分析:当数据库重启后,在数据库buffer中的热数据需要innodb本身去预热.如果buffer太大,依靠innodb自己去预热,将会有很长一个周期才能实现.此时热数据就需要到磁盘去寻找,就给磁盘的I/O带来很大的压力.遇到瓶颈,就会一直等待,导致数据无响应.
解决方法:5.6版本之前,重启mysql后,手工把热数据加载到buffer里面去.如:select count(*) from table_name(热数据表);
5.6版本之后,提供了一个新特性来快速预热buffer_pool缓冲池.在my.cnf里面加入几个参数:
innodb_buffer_pool_dump_at_shutdown = 1 --在关闭数据库时把热数据dump到本地磁盘
innodb_buffer_pool_dump_now = 1 --采用手工方式把热数据dump到本地磁盘
innodb_buffer_pool_load_at_startup = 1 --在启动时把热数据加载到内存
innodb_buffer_pool_load_now = 1 --采用手工方式把热数据加载到内存
在关闭mysql时,会把内存中的热数据保存在磁盘的ib_buffer_pool文件中,该文件位于数据目录下.
ps:只有正常关闭mysql服务,或者pkill mysql时,才会把热数据导出到磁盘.机器宕机或者pkill -9 mysql,是不会导出的.