mysql 与文件系统缓存

Posted 不忘初衷,方能致远

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 与文件系统缓存相关的知识,希望对你有一定的参考价值。

前言:

今天一个朋友问了一个问题,原文如下:mysql5.1,myisam的表,select count(*) as total FROM m_bff WHERE from_uid=‘73149293‘ AND isdeleted=0。from_uid上有索引,第一次执行这个句子速度慢,1秒多,用show profile看都慢在Sending data上。但是紧接着我加上sql_no_cache,执行只需要0.01秒了,有好多句子都是类似的情况第一次慢,后来加上sql_no_cache也不慢,Key_blocks_unused也很多,请教下这种是什么原因呢?

 

问题总结一下就是:对于MyISAM表的查询,为何第一次会比第二次慢非常多?

回想innodb和MyISAM的区别,其中非常重要的一个就是MyISAM只缓存索引内容,而innodb不仅缓存索引还缓存数据。那照理说MyISAM每次的数据查询都应该是Disk Access不会有很大的速度差距吧。

其实在MyISAM的文件和操作系统之间还有一层OS级别的文件缓存。猜测就是OS文件缓存捣的鬼。

验证:

验证方式其实很简单,在shell下以root权限运行 cat 3 > /proc/sys/vm/drop_caches 把OS的文件缓存清空,再运行SQL看看是不是和第一次运行的速度一样就可以知道了。

 

结果:

恩,echo 3 /proc/sys/vm/drop_caches 之后就又慢了,看来就是你说的问题了

 

引申:

知道了MyISAM这个特性后,可以用文件预读的方法来做数据预热。

假设某个表是热点表,且操作系统又有较多的内存空余。我们可以用cat table.MYD >> /dev/null 的方式来把文件加载到OS文件缓存中。这样当某些用户的数据第一次访问时就不会出现慢查询了

以上是关于mysql 与文件系统缓存的主要内容,如果未能解决你的问题,请参考以下文章

Mysql数据库架构介绍

php+mysql缓存技术的实现

Ubuntu 系统缓存的查看与清空(qbit)

mysql数据库innodb引擎的一个重要内核参数swappiness

架构系列四(缓存方案架构设计思考)

MySQL查询和静态缓存的性能比较