代码改变世界

Multi-Queue Replacement Algorithm

2012-05-15 14:49  Demote  阅读(281)  评论(0编辑  收藏  举报

维护MLRU队列.

        请求在Cache中命中时,根据请求被访问的次数计算出它应该处于的LRU队列中(例如,当计算函数为Log2(accesscount),当请求被访问2^i,该请求则被放于第iLRU队列中).

        CacheMiss,从第一条非空的LRU队列中替换出一个块并将其置于Qout队列中.Qout队列用于记录从缓存中替换出去的请求且只记录块的地址指针和访问次数.

        每个缓存中的块有一个有效时间,每次处理请求时,检查各个队列中的第一个块的有效时间,如果超出,则将该块降至前一级LRU链中并重置块有效时间.

        伪代码如下:

 

 


* YuanyuanZhou and James F. Philbin, The Multi-Queue Replacement Algorithm for SecondLevel Buffer Cache, Proceedings of the 2001 USENIX Annual TechnicalConference