这篇文章给大家分享的是有关mysql导致tmp目录空间耗尽怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
收到磁盘空间告警的信息,/tmp目录磁盘使用率99%。
mysql 的 tmpdir 设置在/tmp目录,第一时间查看 ls -alth 并为发现大文件,也没有mysql临时表之类的文件。
连接mysql,show processlist 并为发现异常查询 ……
整个/tmp目录8GB,用查看df -h 发现/tmp Avail 值剩下100MB左右;du -sh 发现tmp目录只用了几十MB。7GB多的空间哪里去了?未释放?
通过lsof |grep tmp |more 发现其中一个mysql实例很多类似 /tmp/MLXvlID8 (deleted)
查看mysqld.err中发现有多行: [ERROR] /mysql_base/bin/mysqld: Sort aborted
猜测:Sql异常终止,导致sort aborted 。而临时目录下的/tmp/ML****** 等文件虽然删除,但由于mysql线程连接是长连接,线程还存在,暂时不会释放空间。
若想释放空间:
1.重启mysql;
2.重启应用程序,断开长连接。
结果:
应用程序重启,长连接断开,删除的空间就释放了。
感谢各位的阅读!关于“mysql导致tmp目录空间耗尽怎么办”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。