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

详解MyISAM Key Cache(中篇)

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

来源:转载

面向PHPt3SgbA/I

前篇中 介绍了Key Cache的基本机制,并且介绍了Key Cache的LRU算法。作为对LRU算法的改进,MyISAM还提供了另一个缓存算法:“Midpoint Insertion Strategy”。本文将重点介绍该算法的原理和配置。

R6l8p+k0f5kp0 面向PHP a9_1\;xd&}

1. 相关参数 面向PHP;u f5D"`:j)yJ+X\

面向PHP+eds'Umol%a

该策略涉及的参数有:key_cache_division_limitkey_cache_age_threshold面向PHPu4]#j'x rEt

面向PHP9eb.r+N"B M"B.N&Ae Dc

2. 原理介绍

1{ L`6N)\0

's+NHtP0(1) 该策略将前面的LRU队列(LRU Chain)分成两部分,hot sub-chain和warm sub-chain。并根据参数key_cache_division_limit划分,总保持warm sub-chain在这个百分比以上。默认情况key_cache_division_limit是100,所以默认时候只有warm sub-chain,即LRU Chain。面向PHPk&[$^:p3w)@2C
(注:Multiple Key cache情况,每个key cache都有对应的key_cache_division_limit值)

#?^:{O+x3R{C9bY!QS0 面向PHPf(X5y+[K F a)F\

(2) 在warm sub-chain中的某个block如果被访问(Access)次数超过某个值时候,就将该block放到hot sub-chain的底部。面向PHP fG H { H _:[

面向PHPk2m.fb CCd)w

(3) 在hot sub-chain中的block会随着每一次的hit调整位置,hit越多,越接近底部。在顶部停留时间过长就会被降级到warm sub-chain中,而且是warm sub-chain的顶部(很可能很快就会被移出key cache)。

4?eEIJ3R0 面向PHP Y7xbg8i ~2PW

(4) Hot sub-chain中的顶部的block停留时间超过一个阈值后就会被降级到warm sub-chain。这个阈值由参数key_cache_age_threshold决定。具体的计算方法是:设N为key cache中的block个数,如果在最近的(N*key_cache_age_threshold/100)次访问中,key cache顶部的block仍然没有被访问到,那么就会被移到warm sub-chain的顶部。面向PHPt8SlT z ~-D1p

面向PHP S"c+e2a"\%~-hEP @

(5) 默认情况key_cache_division_limit = 100,这时只有只有一个Chain,所以不使用该策略。即退化的Midpoint Insertion Strategy是LRU算法。

U7Z `S8S*rb+^0 面向PHPRF'p S ~

3. 如何使用Midpoint Insertion Strategy

c{bV$rF u6`|0 面向PHPDJTx`Cny)LDIT

我们可以通过配置key_cache_division_limitkey_cache_age_threshold的 值来控制。参数key_cache_division_limit控 制了Key Cache Chain中warm sub-chain的百分比,如果你的Index Block中明显有30%是非常Hot(较之其他的Block更加被常常访问),那么你可以设置你的warm sub-chain长度为70%,剩余30%作为hot sub-chain。参数key_cache_age_threshold定 义了warm sub-chain中的block被移除的机制(参照前文介绍)。面向PHP7I-U3S ?,_V U

TAG: Cache Key MyISAM 详解 中篇
顶:6 踩:9
对本文中的事件或人物打分:
当前平均分:-0.79 (24次打分)
对本篇资讯内容的质量打分:
当前平均分:-1.36 (22次打分)
【已经有28人表态】
7票
感动
1票
路过
5票
高兴
6票
难过
3票
搞笑
1票
愤怒
2票
无聊
3票
同情
上一篇 下一篇
发表评论

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

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