MySQL运维19-InnoDB的临时文件

1、临时文件的作用

  • 进行排序时(ORDER BY或GROUP BY),MySQL通常会使用1个或多个临时文件。
  • 对于某些SELECT查询,MySQL会创建临时SQL表。
  • ALTER TABLE会在与原始表目录相同的目录下创建临时表。

2、临时文件的位置

MySQL使用环境变量TMPDIR的值作为保存临时文件的目录路径名。如果未设置TMPDIR,那么MySQL将使用系统的默认值,通常为/tmp、/var/tmp或/usr/tmp。

3、临时文件的注意事项

  • 如果包含临时文件目录的文件系统过小,则可以对mysqld使用“–tmpdir”选项,或者修改配置文件内的参数tmpdir,从而在具有足够空间的文件系统内指定1个临时文件目录,
  • 对于大数据量的排序,临时空间容量可能会超过/tmp空间,此时,执行查询将会失败,MySQL错误日志里会出现错误记录“sort abort”。解决方案是优化查询或把临时目录设置到另一个空间足够大的分区中。
  • 如果MySQL服务器正作为从服务器使用,那么不应将“–tmpdir”设置为指向基于内存的文件系统的目录,因为服务器主机重启时将要清空的临时文件目录。而对于从服务器,需要在机器重启时仍保留一些临时文件,以便能够复制临时表或执行LOAD DATA INFILE操作。

4、总结

  1. 临时文件主要应用在ORDER BY、GROUP BY、表连接等查询场景下,ALTER TABLE操作也会在与原始表目录相同的目录下创建临时表。
  2. MySQL使用环境变量TMPDIR的值作为保存临时文件的目录路径名。如果未设置TMPDIR,那么MySQL将使用系统的默认值,通常为/tmp、/var/tmp或/usr/tmp。

猜你喜欢

转载自blog.csdn.net/oddrock/article/details/130173664
今日推荐