IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

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

    夜行人发表于 2014-08-11 11:23:07
    love 0

    最近有台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、不导整个库的结构,一个表一个表地导(这个也是目前的做法),或者直接就不导结构,因为都是一样的



沪ICP备19023445号-2号
友情链接