我的编程空间,编程开发者的网络收藏夹
学习永远不晚

物理写的判断 & 介质恢复 & 实例恢复 & 增量检查点

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

物理写的判断 & 介质恢复 & 实例恢复 & 增量检查点

物理写的检测:

select  * from v$sysstat where lower(name) like 'physical writes%';

 physical writes 119             //我一共写了多少块

 

select * from v$sysstat where upper(name) like 'DBW%';

 104 DBWR checkpoint buffers written 173 12  //通过检查点写了多少块。

那你就可以用  buffer writer / physical writers      基本在百分之六,七十  算正常。

测试:


SYS@_connect_identifier>
SYS@_connect_identifier>select * from v$sysstat where upper(name) like 'DBWR%';
STATISTIC# NAME CLASS VALUE STAT_ID
---------- ---------------------------------------------------------------- ---------- ---------- ----------
       104 DBWR checkpoint buffers written 8 259 1208600358
       105 DBWR thread checkpoint buffers written 8 0 3905787588
       106 DBWR tablespace checkpoint buffers written 8 0 2649259263
       107 DBWR parallel query checkpoint buffers written 8 0 1768645316
       108 DBWR object drop buffers written 8 0 658143835
       109 DBWR transaction table writes 8 19 2146120386
       110 DBWR undo block writes 8 73 111270822
       111 DBWR revisited being-written buffer 8 0 2773697723
       112 DBWR lru scans 8 0 2139101792


     

  113 DBWR checkpoints 8 0 1732023165
       114 DBWR fusion writes 40 0 2313150541
已选择11行。
SYS@_connect_identifier>select * from v$sysstat where lower(name) like 'physical writ%';
STATISTIC# NAME CLASS VALUE STAT_ID
---------- ---------------------------------------------------------------- ---------- ---------- ----------
        48 physical write total IO requests 8 1301 1315894329
        49 physical write total multi block requests 8 5 3540174003
        50 physical write total bytes 8 16102400 2495644835
        83 physical writes 8 272 1190468109
        84 physical writes direct 8 13 2699895516
        85 physical writes from cache 8 259 163083034
        86 physical write IO requests 8 187 2904164198
        89 physical writes direct temporary tablespace 8 9 996415569
        90 physical write bytes 8 2228224 3131337131
       102 physical writes non checkpoint 8 246 2602029796
       156 physical writes direct (lob) 8 4 3308932835
已选择11行。


SYS@_connect_identifier>select 259/272 from dual;
   259/272
----------
.952205882





那什么时候Oracle会做实例恢复呢?

其实Oracle是有一个标志位的当他为1 时打开就实例恢复,当他为0 时,那就不恢复喽:

主要在 v$DATAFILE 中 有一个参数   last_time  和last_change#.  

 

你可以先将数据库mount状态,然后查询    

select  last_time, last_change# from v$DATAFILE;

就可以观察出来。出现结果了就是正常关闭,如果没有结果那就是异常关闭。



判断文件是否需要介质恢复:

v$datafile;   来自控制文件

v$datafile_header 来自数据文件头。


col name for a40
select name,CHECKPOINT_CHANGE#, CHECKPOINT_TIME FROM V$DATAFILE;
SELECT CHECKPOINT_CHANGE# FROM V$DATAFILE_HEADER;



如果出现那个文件检查点不一样,那就需要介质恢复。



测试:

先热备一下一个文件:

rman target /
backup datafile '/u01/app/oracle/oradata/test/test_01'  format  '/tmp/test_01%U.bak';


更改时间格式:

alter  session set nls_date_format='yyyy-mm-dd hh34:mi:ss';



那oracle  里面还有个v$database 的checkpoint_change#  和  v$datafile_header   比较如果前者小于后者,那么就说明控制文件太旧,需要恢复。

alter database mount 
recover database open noresetlog


 恢复的话,怎样避免resetlog 呢(日志文件号归零)


可以 使用重建控制文件  :

sql> alter database backup controlfile to trace;

然后在跟踪文件中找到语句,shutdown 数据库后 nomount 后  使用重建控制文件语句。之后recover database;     最后 alter database  open;





增量检查点:

1)  ckptq (检查点队列) 你做任何修改操作的时候,Oracle都会先获得chpt latch锁

2) dbwr  没3秒检查chptq长度,过长的话,就将他写入磁盘

3)ckpt  没3秒将第一块中的RBA (redo  block address)写入到控制文件




免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

物理写的判断 & 介质恢复 & 实例恢复 & 增量检查点

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

目录