你的位置:面向PHP >> 资讯 >> 数据库 >> Mysql >> 详细内容 在线投稿

详解MyISAM Key Cache(前篇)

热度99票  浏览45次 【共0条评论】【我要评论 时间:2010年2月03日 10:39
文章信息

来源:转载

esO+W%fSE0本文将分为前、中、后三篇,分别介绍MyISAM Key Cache的一般机制、Mid-point strategy、状态、参数和命令。面向PHP3`.k!vRg~j'o

-Car,W"Ll(VU,b0“Cache为王”,无所不在。为了最小化磁盘I/O,MyISAM将最频繁访问的索引块(“index block”)都放在内存中,这样的内存缓冲区我们称之为Key Cache,它的大小可以通过参数key_buffer_size来控制。在MyISAM的索引文件中(MYI),连续的单元(contiguous unit)组成一个Block,Index block的大小等于该BTree索引节点的大小。Key Cache就是以Block为单位的。

@DA'g#A0面向PHP#rh O;?4wI-B

1. MyISAM如何使用Key Cache

3i)Ay'V LX |N0面向PHPGU+l0V]%Y1a;w

当MySQL请求(读或写)MyISAM索引文件中某个Index Block时,首先会看Key Cache队列中是否已经缓存了对应block。如果有,就直接在Key Cache队列中进行读写了,不再需要请求磁盘。如果是写请求,那么Key Cache中的对应Block就会被标记为Dirty(和磁盘不一致)。在MyISAM在Key Cache成功请求(读写)某个Block后,会将该Block放到Key Cache队列的头部。

1iV&?D\ Su0

u } tGOt0如果Key Cache中没有待请求(读或写)的Block,MyISAM会向磁盘请求对应的Block,并将其放到Key Cache的队列头部。队列如果满了,会将队列尾部的Block删除,该Block如果是Dirty的,会将其Flush到磁盘上。我们看到MyISAM维护了一个LRU(Least Recently Used)的Key Cache队列。队列中的Dirty Block会在Block被踢出队列时Flush到磁盘上。面向PHP6z)jKo({U

,PG'B3r,t1NlT02. 图解

tv:X/x3hx,?&J5c1kI0面向PHP:\ia:Sh"Ot M s5E

下图展示了访问Index Block的过程:(黑色部分为磁盘中的Index文件)面向PHP1B$tpT1`w"Y%l z,q%q4[?0P

OU(? |i%`[ge0Keycache面向PHP;X(g3hS'nN8Hq

fEfZ7l)IT:x03. 并发访问

2Z#Z(LxF k0

b cQ'T EL0Key Cache中的index Block是可以被并发访问的(Shared access ),下面是一些规则:面向PHP ^*W"_m D

  1. 多个没有更新操作的session可以并发同一个block buffer
  2. 多个session同时访问某一个block buffer,如果某个session是update操作,则优先访问
  3. 多个session如果都需要进行block replacement,是可以并发操作。(从index file中读取block更新到key cache,但是key cache已满,需要删除一些block buffer的操作叫做block replacement)

B.Q J!L/w_l@0 

Gq{;pJMQiy0面向PHP,}$Puj#lG,[

4. 补充说明面向PHPj`7y C-Rth)b

u Z#iI:Uv%n0Key cache中的Block大小可能和索引文件中的Index Block大小不同,可能是大于、小于、等于中的任何一种,但是一般都是成倍数关系的。Key Cache的block大小由参数Key_cache_block_size控制。

5g!qW;N+M Bt.|.vk0
TAG: MyISAM 详解 Cache Key
顶:8 踩:7
对本文中的事件或人物打分:
当前平均分:-1.14 (35次打分)
对本篇资讯内容的质量打分:
当前平均分:-1.04 (24次打分)
【已经有25人表态】
8票
感动
3票
路过
1票
高兴
3票
难过
3票
搞笑
2票
愤怒
3票
无聊
2票
同情
上一篇 下一篇
发表评论

网友评论仅供网友表达个人看法,并不表明本网同意其观点或证实其描述。

查看全部回复【已有0位网友发表了看法】