最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

将MySQL的临时目录建立在内存中的教程

来源:动视网 责编:小采 时间:2020-11-09 15:12:06
文档

将MySQL的临时目录建立在内存中的教程

将MySQL的临时目录建立在内存中的教程:MySQL 系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢你可以通过下面命令获知: mysql SHOW GLOBAL STATUS LIKE 'Created_tmp%tables'; +--------------
推荐度:
导读将MySQL的临时目录建立在内存中的教程:MySQL 系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢你可以通过下面命令获知: mysql SHOW GLOBAL STATUS LIKE 'Created_tmp%tables'; +--------------


MySQL 系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢?你可以通过下面命令获知: mysql SHOW GLOBAL STATUS LIKE 'Created_tmp%tables'; +-------------------------+----------+ | Vari

  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 文件来改变这个路径,然后重启数据库。

文档

将MySQL的临时目录建立在内存中的教程

将MySQL的临时目录建立在内存中的教程:MySQL 系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢你可以通过下面命令获知: mysql SHOW GLOBAL STATUS LIKE 'Created_tmp%tables'; +--------------
推荐度:
标签: 创建 教程 创建的
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top