将MySQL的临时目录建立在内存中的教程
MySQL系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢?你可以通过下面命令获知:
mysql>SHOWGLOBALSTATUSLIKE'Created_tmp%tables'; +-------------------------+----------+ |Variable_name|Value| +-------------------------+----------+ |Created_tmp_disk_tables|49094| |Created_tmp_tables|37842181| +-------------------------+----------+
很显然,在内存中的临时表的性能要比在磁盘中好得多得多,因此我们希望尽可能的在内存中建立临时表。
为了实现这个要求,我们先检查下临时表的配置大小:
mysql>SHOWGLOBALVARIABLESLIKE'%table_size'; +---------------------+----------+ |Variable_name|Value| +---------------------+----------+ |max_heap_table_size|25165824| |tmp_table_size|25165824| +---------------------+----------+
如果临时表的大小比上述值小,则放于内存中的MEMORY表;如果比上述值大则存放于磁盘中的MyISAM表。
但还有一个其他的因素会导致存放到磁盘的MyISAM表,那就是MEMORY表不能处理TEXT和BLOG类型数据。这种情况下MySQL会直接写入磁盘中的MyISAM,并算作是Created_tmp_disk_tables的值。
如果临时表已经开始导致严重的I/O性能问题,那么你就要考虑使用磁盘内存映射来代替物理磁盘。
在Linux上我们有两种方法在内存中建立RAM-Disk,分别是ramfs和tmpfs。
这里我们推荐使用tmpfs。
可通过如下命令来创建RAM-disk:
shell>mkdir-p/mnt/ramdisk shell>chownmysql:mysql/mnt/ramdisk shell>mount-ttmpfs-osize=512Mtmpfs/mnt/ramdisk
为了在系统下次启动时自动创建,我们可以将下列脚本置于/etc/fstab文件中:
tmpfs/mnt/ramdisktmpfsrw,mode=177700
MySQL还是将数据写到默认的磁盘,可通过下面命令来检查:
mysql>SHOWGLOBALVARIABLESLIKE'tmpdir';
+---------------+-------+ |Variable_name|Value| +---------------+-------+ |tmpdir|/tmp| +---------------+-------+
你可以修复my.cnf文件来改变这个路径,然后重启数据库。