• 爱情文章
  • 亲情文章
  • 友情文章
  • 生活随笔
  • 校园文章
  • 经典文章
  • 人生哲理
  • 励志文章
  • 搞笑文章
  • 心情日记
  • 英语文章
  • 范文大全
  • 作文大全
  • 新闻阅读
  • 当前位置: 山茶花美文网 > 作文大全 > 正文

    【将MySQL的临时目录建立在内存中的教程】 如何扩大手机自带内存

    时间:2020-05-13来源:山茶花美文网 本文已影响 山茶花美文网手机站

    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 |

    +---------------+-------+

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

    • 【将MySQL的临时目录建立在内存中的教程】 如何扩大手机自带内存 相关文章:
    • 爱情文章
    • 亲情文章
    • 友情文章
    • 随笔
    • 哲理
    • 励志
    • 范文大全