| 您的当前位置:首页 --> MYSQL教程 --> 将MySQL的临时目录建立在内存中的教程 |
| MYSQL教程 将MySQL的临时目录建立在内存中的教程 |
| 浏览次数:1075 关键词 ( ) |
| 查看使用该CPU的产品 查看CPU天梯 |
| CPU型号:将MySQL的临时目录建立在内存中的教程 |
| 主频:Ghz |
| 睿频:Ghz |
| 核心数:个 |
| 不支持超核心 |
| 制作工艺: |
| 插槽类型: |
| 功耗:0W |
| L3缓存:0MB |
| 支持最大内存: 0GB |
| CPU详细参数 |
|
MySQL 系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢?你可以通过下面命令获知: mysql> SHOW GLOBAL STATUS LIKE 'Created_tmp%tables'; +-------------------------+----------+ | Variable_name | Value | +-------------------------+----------+ | Created_tmp_disk_tables | 49094 | | Created_tmp_tables | 37842181 | +-------------------------+----------+ 很显然,在内存中的临时表的性能要比在磁盘中好得多得多,因此我们希望尽可能的在内存中建立临时表。 为了实现这个要求,我们先检查下临时表的配置大小: mysql> SHOW GLOBAL VARIABLES LIKE '%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> chown mysql:mysql /mnt/ramdisk shell> mount -t tmpfs -o size=512M tmpfs /mnt/ramdisk 为了在系统下次启动时自动创建,我们可以将下列脚本置于 /etc/fstab 文件中: tmpfs /mnt/ramdisk tmpfs rw,mode=1777 0 0 MySQL 还是将数据写到默认的磁盘,可通过下面命令来检查: mysql> SHOW GLOBAL VARIABLES LIKE 'tmpdir'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | tmpdir | /tmp | +---------------+-------+ 你可以修复 my.cnf 文件来改变这个路径,然后重启数据库。 |
| 下一个产品 SQL计算timestamp的差值的方法 上一个产品 介绍使用WordPress时10个常用的MySQL查询 |