在内存中建立 MySQL 的临时目录(转)
2016-02-17 23:28
471 查看
MySQL 系统会在内存(MEMORY)和磁盘(MyISAM)中建立临时表,如何能知道在磁盘中建立了多少临时表以及在内存中建立多少临时表呢?你可以通过下面命令获知:
?
很显然,在内存中的临时表的性能要比在磁盘中好得多得多,因此我们希望尽可能的在内存中建立临时表。
为了实现这个要求,我们先检查下临时表的配置大小:
?
如果临时表的大小比上述值小,则放于内存中的 MEMORY 表;如果比上述值大则存放于磁盘中的 MyISAM 表。
但还有一个其他的因素会导致存放到磁盘的 MyISAM 表,那就是 MEMORY 表不能处理 TEXT 和 BLOG 类型数据。这种情况下 MySQL 会直接写入磁盘中的 MyISAM,并算作是 Created_tmp_disk_tables 的值。
如果临时表已经开始导致严重的 I/O 性能问题,那么你就要考虑使用磁盘内存映射来代替物理磁盘。
在 Linux 上我们有两种方法在内存中建立 RAM-Disk,分别是 ramfs 和 tmpfs。
这里我们推荐使用 tmpfs。
可通过如下命令来创建 RAM-disk:
?
为了在系统下次启动时自动创建,我们可以将下列脚本置于 /etc/fstab 文件中:
?
MySQL 还是将数据写到默认的磁盘,可通过下面命令来检查:
?
你可以修复 my.cnf 文件来改变这个路径,然后重启数据库。
英文原文,OSCHINA原创翻译
http://www.oschina.net/question/12_79459
在stackoverflow上看到过类似的问题
http://stackoverflow.com/questions/7532307/skip-copying-to-tmp-table-on-disk-mysql
?
为了实现这个要求,我们先检查下临时表的配置大小:
?
但还有一个其他的因素会导致存放到磁盘的 MyISAM 表,那就是 MEMORY 表不能处理 TEXT 和 BLOG 类型数据。这种情况下 MySQL 会直接写入磁盘中的 MyISAM,并算作是 Created_tmp_disk_tables 的值。
如果临时表已经开始导致严重的 I/O 性能问题,那么你就要考虑使用磁盘内存映射来代替物理磁盘。
在 Linux 上我们有两种方法在内存中建立 RAM-Disk,分别是 ramfs 和 tmpfs。
这里我们推荐使用 tmpfs。
可通过如下命令来创建 RAM-disk:
?
?
?
英文原文,OSCHINA原创翻译
http://www.oschina.net/question/12_79459
在stackoverflow上看到过类似的问题
http://stackoverflow.com/questions/7532307/skip-copying-to-tmp-table-on-disk-mysql
相关文章推荐
- Mysql常用函数
- mysql校对规则设计编码命令
- .NET/Mysql-petatoco连接mysql数据库
- MySQL知识(二)——数据表的基本操作
- MySQL 作为新的 NoSQL 解决方案: 轻松应对亿级数据
- 古诗mysql数据库设计
- 连接MySQL数据库时常见故障问题的分析与解决
- MySQL limit分页查询优化写法
- solr对mysql中tinyint字段的处理方法
- mysql经纬度查询
- mysql调优
- MySQL主从复制原理
- Mysql“集群”和”主从“两者的区别
- MySql语句集合类
- MYSQL集群
- Spark将计算结果写入到Mysql中
- MYSQL死掉后自动重启脚本
- mysql主从
- mysql下将分隔字符串转换为数组
- 不同场景下 MySQL 的迁移方案