Oracle体系结构中经常看到LRU算法,Least Recently Used,也有叫“最近最少使用页面置换算法”,简单讲,Oracle会将内存中最近不用的数据库移出内存以腾出空间来加载另外的数据。算法的实现虽然无法获取,但对于我们很多人来说,也没有必要了解。更重要、更实际地是知道它的作用,以及基于此对一些问题的分析与判断。
关于这个算法,有一种最理想的计算,就是每次调换出的内存是所有内存中最迟将被使用的,可以最大限度地推迟内存调换,但这种算法是理想内存置换,无法实现。为了减少与理想算法的差距,又出现了各种精妙的算法,LRU就是其中一个。它是基于:前面内存中的数据很可能在后面频繁使用,反过来说,已经很久没用的内存中数据可能在未来较长时间内不会被用到,这是著名的局部性原理,比内存速度还要快的cache,也是基于同样的原理运行的。因此我们只需要在每次内存调换时,找到最近最少使用的内存数据调出内存,这就是LRU算法的内容。
有的书中提到的“如果数据库空运转,最终DBWR会将全部缓冲区存储区写入磁盘”,DBWR会将dirty缓冲区写入磁盘,使用的是LRU算法,如上原理所述,根据DBWR触发的若干条件,外加LRU算法,DBWR当然会将全部buffer cache写入磁盘。
【Oracle】-【LRU和DBWR】-LRU算法与DBWR中的应用
原创
©著作权归作者所有:来自51CTO博客作者wx5b8b656889613的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
【Oracle】-【体系结构-DBWR】-DBWR进程相关理解
对DBWR的一些理解首先从名称上,DBWR全称是
oracle 体系结构 DBWR 缓存 表空间 -
缓存淘汰算法--LRU算法的原理与应用
本文LRU算法的含义、应用、Java实现。LRU算法全称是:Least Recently Used,即:检查最近最少使用的数据。
java jvm servlet 数据 链表 -
FIFO算法与LRU算法
基于页号存入存储块的FIFO和LRU算法
FIFO和LRU算法 -
[转帖]DBWR与LGWR的写入机制数据 数据库 后台进程