mysql导致tmp目录空间耗尽

PHPz
發布: 2019-02-25 16:58:15
原創
3018 人瀏覽過

问题:

收到磁盘空间告警的信息,/tmp目录磁盘使用率99%。mysql 的 tmpdir 设置在/tmp目录,第一时间查看 ls -alth 并为发现大文件,也没有mysql临时表之类的文件。连接mysql,show processlist 并为发现异常查询 ……整个/tmp目录8GB,用查看df -h 发现/tmp Avail 值剩下100MB左右;du -sh 发现tmp目录只用了几十MB。7GB多的空间哪里去了?未释放?

相关mysql视频教程推荐:《mysql教程

通过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.重启应用程序,断开长连接。

结果:

应用程序重启,长连接断开,删除的空间就释放了。


來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板