zoukankan      html  css  js  c++  java
  • 在内存中建立 MySQL 的临时目录(转)

    MySQL 系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢?你可以通过下面命令获知:

    1
    2
    3
    4
    5
    6
    7
    mysql> SHOW GLOBAL STATUS LIKE 'Created_tmp%tables';
    +-------------------------+----------+
    | Variable_name           | Value    |
    +-------------------------+----------+
    | Created_tmp_disk_tables | 49094    |
    | Created_tmp_tables      | 37842181 |
    +-------------------------+----------+

    很显然,在内存中的临时表的性能要比在磁盘中好得多得多,因此我们希望尽可能的在内存中建立临时表。

    为了实现这个要求,我们先检查下临时表的配置大小:

    1
    2
    3
    4
    5
    6
    7
    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:

    1
    2
    3
    shell> mkdir -p /mnt/ramdisk
    shell> chown mysql:mysql /mnt/ramdisk
    shell> mount -t tmpfs -o size=512M tmpfs /mnt/ramdisk

    为了在系统下次启动时自动创建,我们可以将下列脚本置于 /etc/fstab 文件中:

    1
    tmpfs           /mnt/ramdisk     tmpfs   rw,mode=1777    0       0

    MySQL 还是将数据写到默认的磁盘,可通过下面命令来检查:

    1
    2
    3
    4
    5
    6
    mysql> SHOW GLOBAL VARIABLES LIKE 'tmpdir';
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | tmpdir        | /tmp  |
    +---------------+-------+

    你可以修复 my.cnf 文件来改变这个路径,然后重启数据库。

    英文原文OSCHINA原创翻译

    http://www.oschina.net/question/12_79459

    在stackoverflow上看到过类似的问题

    http://stackoverflow.com/questions/7532307/skip-copying-to-tmp-table-on-disk-mysql

  • 相关阅读:
    您认为在测试人员同开发人员的沟通过程中,如何提高沟通的效率和改善沟通的效果?维持测试人员同开发团队中其他成员良好的人际关系的关键是什么?
    redis和jedis的用法,区别
    Jedis实现多种功能总结
    Druid简单介绍
    Svn与Git的区别
    SVN的一些基本概念(学前了解)
    Redis-cli 的功能
    postman的使用方法
    Spring Boot 有哪些优点?
    Redis中的常用命令哪些?
  • 原文地址:https://www.cnblogs.com/softidea/p/5196861.html
Copyright © 2011-2022 走看看