寻觅生命中的那一片浅草......

mysqldump引起mysql内存飙升事例一则

最近有台MySQL,在运行一段时间后,res和virt内存都会去到很高,res会占到物理内存的90%,
期间做过的尝试:
1、用tcpcopy来把生产环境的流量导到测试服,但MySQL内存并无异常
2、将innodb_file_per_table=1修改为innodb_file_per_table=0,运行1天后,内存飙升还是比较厉害
同事看监控,发现在凌晨,MySQL备份后,内存才飙升

最后查找到MySQL内存异常的原因是以下2个:
1、xxx_db下表太多:近2W了
2、由于表太多,${MYSQLDUMP} -uroot -p${MYSQLPASSWORD} -d $1 > “${BACKUPDIR}/$1_db_struc.sql”这个指令把整个库的表结构导出来的时候,估计会把整个结构先写入内存

解决办法:
1、减少表数量
2、不导整个库的结构,一个表一个表地导(这个也是目前的做法),或者直接就不导结构,因为都是一样的

2020年七月
« 2月    
 12345
6789101112
13141516171819
20212223242526
2728293031