CKPT检查点队列
CKPT检查点队列
buffer cache内存包含chain和buffer
LRU 将可用块串起来(按访问的频率)
LRUW 将脏块串起来(访问频率)冷端的块率先被写入硬盘。
CBC 将数据块读入内存的时候使用
CKPT(链): 1、链接的是脏块 2、第一次脏的时间链接起来的(从小到大)
RBA redo block address 日志块的地址
对块修改会产生日志,日志存在一个地址。这个地址就是RBA。
同时在修改的块记录下这个RBA地址。
对于每一个块存在2个地址:
LRBA(第一次被脏的地址)
HRBA(最后一次被脏的地址)
检查点队列里面的数据块是按照数据块的LRBA地址链接的。
CKPT有2中工作方式:1、完全检查点:会触发DBWR将所有脏块写到磁盘(关闭数据库)
2、增量检查点:
a、主要是将检查点队列的对应的LRBA(第一个脏块所对应的日志地址)记录到控制文件中(每隔3秒)
b、当增量检查点发生的时候,会检查检查点队列,当队列的上的脏块太多且系统不是很忙的时候会触发dbwr去缩短检查点队列。
dbwr写有2种情况:
1、LRUW
2、检查点队列最早脏的块部分写在磁盘上
on disk rba logbuffer 数据库保存的最后一条的日志地址 (logbuffer里面最后一条日志地址即记录的最新的日志地址) col LowRBA for a20 col OndiskRBA for a20 select CPDRT, CPLRBA_SEQ||'.'||CPLRBA_BNO||'.'||CPLRBA_BOF "LowRBA", CPODR_SEQ||'.'||CPODR_BNO||'.'||CPODR_BOF "OndiskRBA", CPODS, CPODT, CPHBT from x$kcccp; alter system flush buffer_cache CPDRT列是检查点队列中的脏块数目. CPODS列是on disk rba的scn CPODT列是on disk rba的时间戳 CPHBT列是心跳
相关操作
select checkpoint_change# from v$database alter system checkpoint alter system switch logfile select name,checkpoint_change# from v$datafile select name,checkpoint_change# from v$datafile_header select * from v$log; begin for i in 1..10000 loop insert into t2 values(1,'xkj'); commit; end loop; end; select * from t2