• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 将MySQL的临时目录建立在内存中的教程

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mysql安装目录,查看mysql安装目录,linux mysql安装目录,mysql没有bin目录,查找mysql安装目录等相关知识,希望本文的分享对您有所帮助

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

mysql> SHOW GLOBAL STATUS LIKE 'Created_tmp%tables';
+-------------------------+----------+
| Variable_name      | Value  |
+-------------------------+----------+
| Created_tmp_disk_tables | 49094  |
| Created_tmp_tables   | 37842181 |
+-------------------------+----------+
</div>

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

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

mysql> SHOW GLOBAL VARIABLES LIKE '%table_size';
+---------------------+----------+
| Variable_name    | Value  |
+---------------------+----------+
| max_heap_table_size | 25165824 |
| tmp_table_size   | 25165824 |
+---------------------+----------+
</div>

如果临时表的大小比上述值小,则放于内存中的 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
</div>

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

 

tmpfs      /mnt/ramdisk   tmpfs  rw,mode=1777  0    0
</div>

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

mysql> SHOW GLOBAL VARIABLES LIKE 'tmpdir';
</div>
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| tmpdir    | /tmp |
+---------------+-------+
</div>

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

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MySQL慢查询查找和调优测试
  • 将MySQL的临时目录建立在内存中的教程
  • MySQL重定位数据目录的方法

相关文章

  • 2017-05-11mysql 精简过程(删除一些文件)
  • 2017-05-11在MySQL中实现二分查找的详细教程
  • 2018-12-05SQL Server触发器及触发器中的事务学习
  • 2018-12-05解析PHP编程计算两个时间段是否有交集的实现方法
  • 2017-05-11winxp 安装MYSQL 出现Error 1045 access denied 的解决方法
  • 2018-12-05mysql 5.7.19在centos6.5下的安装配置详解
  • 2018-12-05有钱 Python,没钱 PHP,编程语言也嫌贫爱富
  • 2018-12-05详细介绍MySQL之-Centos安装多个mysql数据库的配置实例
  • 2018-12-05MySQL数据库下用户及用户权限配置_MySQL
  • 2018-12-05SQL2008中 阻止保存要求重新创建表的更改 的解决方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • php实现标签云的代码
    • 一个基于ROW_NUMBER()的通用分页存储过程代码
    • MySQL 事务表和非事务表
    • navicat无法远程连接mysql的解决方法
    • 使用SQL语句操作数据表的图文详解(phpMyAdmin的使用教程3)
    • plsql与tsql的语法不同
    • MySQL中or语句用法示例
    • 发现mysql一个用法,比较有用
    • MySql 备忘录
    • SQL Server全文检索查询浅析

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有