【MySQL】MySQL的tmpdir临时文件说明及使用设置

【MySQL】MySQL的tmpdir临时文件说明及使用设置,第1张

MySQL临时目录用于存储临时文件或临时表,值可以是一个使用“:”(Unix)或“”(Windows)分隔的路径列表,这些路径可被轮流使用,以便将负载分到不同磁盘。 若MySQL server是作为Slave的角色,则不能将该目录指向基于内存文件系统的目录或者当主机重启时会被清理掉的目录,因为Slave需要这些文件复制临时表或执行LOAD DATA INFILE *** 作,这些文件丢失会导致复制失败。这意味着不能将slave的tmpdir设置为linux系统默认的/tmp目录。 对于Slave可以使用另一配置项slave_load_tmpdir来设置其临时目录,这样Slave可以不使用通用选项tmpdir设置的临时目录,对于非Slave角色的MySQL server没此限制。 若临时目录不存在或权限不正确不仅会引起MySQL Server启动失败还会导致其他可能使用到临时目录的MySQL实用程序运行异常。很多MySQL相关程序会从MySQL Server的配置文件读取选项值。MySQL 日志配置http://xiaochencui.github.io/2018/01/03/mysql-%E6%97%A5%E5%BF%97%E9%85%8D%E7%BD%AEMySQL的tmpdir临时文件说明及使用设置https://www.cnblogs.com/paul8339/p/11983747.html一个MysQL /tmp目录爆满问题的处理https://blog.51cto.com/lee90/1939469Shall I change the mysql tmpdir from /tmp to /var/lib/mysql/tmp ?https://serverfault.com/questions/431640/mysql-shall-i-change-the-mysql-tmpdir-from-tmp-to-var-lib-mysql-tmpMySQL 临时目录https://blog.csdn.net/zyz511919766/article/details/38084515How to know if mysql tmpdir is being used?https://dba.stackexchange.com/questions/159296/how-to-know-if-mysql-tmpdir-is-being-usedMySQL, RAM disk for tmpdir https://dba.stackexchange.com/questions/94304/mysql-ram-disk-for-tmpdir-how-to-figure-out-what-size-it-should-beChanging the tmp folder of MySQLhttps://stackoverflow.com/questions/11990887/changing-the-tmp-folder-of-mysql

ZDNet至顶网软件频道 mysql导致tmp目录空间耗尽, mysql 的 tmpdir 设置在/tmp目录,第一时间查看 ls -alth 并为发现大文件,也没有mysql临时表之类的文件。

收到磁盘空间告警的信息,/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.重启应用程序,断开长连接。

结果:

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

今天在做LNMP环境的时候,mysql启动失败,LNMP环境是用的oneinstack一键安装脚本安装的。

大致意思是因为 /tmp 目录缺少启动文件( mysql.pid )导致的,恩,于是参照网上提供的方法,修改 /etc/my.cnf 文件

修改pid文件的存放目录,然后 chmod -R 777 /var/lib/mysql/

重新启动,恩?失败!!

那继续,还有大佬说查看mysql报错日志

等会,好像有什么不对啊,今天明明是11-06,你这个11-04什么鬼!!!!

绝望~

然后冷静下来,想到,刚刚查看日志文件为什么会显示权限不够,什么时候vi都要超级管理员权限了。

然后 ll 看了一下文件的所属

嗯哼,这个1002是什么鬼,顿时发现问题

创建mysql用户和mysql组

nice启动成功了!!!

开心~~


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8515658.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-17
下一篇 2023-04-17

发表评论

登录后才能评论

评论列表(0条)

保存