自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle的DBV命令行工具用法詳解

數據庫 Oracle
DBV(DBVERIFY)是Oracle提供的一個命令行工具,它可以對數據文件物理和邏輯兩種一致性檢查。但是這個工具不會檢查索引記錄和數據記錄的匹配關系,這種檢查必須使用analyze validate structure命令。

[[194071]]

DBV(DBVERIFY)是Oracle提供的一個命令行工具,它可以對數據文件物理和邏輯兩種一致性檢查。但是這個工具不會檢查索引記錄和數據記錄的匹配關系,這種檢查必須使用analyze validate structure命令。

這個工具有如下特點:

  • 以只讀的方式打開數據文件,在檢查過程中不會修改數據文件的內容。
  • 可以在線檢查數據文件,而不需要關閉數據庫。
  • 不能檢查控制文件和日志文件,只能檢查數據文件。
  • 這個工具可以檢查ASM文件,但數據庫必須Open狀態(tài),并且需要通過USERID指定用戶,比如:dbv file=+DG1/ORCL/datafile/system01.dbf userid=system/sys
  • 在許多UNIX平臺下,DBV要求數據文件有擴展名,如果沒有可以通過建立鏈接的方法,然后對鏈接的方法,然后對鏈接文件進行操作,比如:ls -n /dev/rdsk/mydevice /tmp/mydevice.dbf
  • 某些平臺,DBV工具不能檢查超過2GB的文件,如果碰到DBV-100錯誤,請先檢查文件大小,MOS Bug 710888對這個問題有描述。
  • DBV只會檢查數據塊的正確性,但不會關系數據塊是否屬于哪個對象。
  • 對于祼設備建議指定END參數,避免超出數據文件范圍。比如:dbv FILE=/dev/rdsk/r1.dbf END=<last_block_number>??梢栽趘$datafile視圖中用bytes字段除以塊大小來獲得END值。

參數                                        含義                                                                                                        缺省值

FILE                                       要檢查的數據文件名                                                                              沒有缺省值

START                               檢查起始數據塊號                                                                           數據文件的***個數據塊

END                                       檢查的***一個數據塊號                                                                   數據文件的***一個數據塊

BLOCKSIZE                       數據塊大小,這個值要和數據庫的DB_BLOCK_SIZE參數值一致            缺省值8192

LOGFILE                               檢查結果日志文件                                                                            沒有缺省值

FEEDBAK                       顯示進度                                                                                            0

PARFILE                               參數文件名                                                                                         沒有缺省值

USERID                               用戶名、密碼                                                                                沒有缺省值

SEGMENT_ID                       段ID,參數格式<tsn.segfile.segblock>                                          沒有缺省值

使用示例:

  1. [oracle@rhel6 ~]$ dbv file=/u01/app/oracle/oradata/test/users01.dbf 
  2.  
  3. DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 16:42:26 2017 
  4.  
  5. Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved. 
  6.  
  7. DBVERIFY - Verification starting : FILE = /u01/app/oracle/oradata/test/users01.dbf 
  8.  
  9. DBVERIFY - Verification complete 
  10.  
  11. Total Pages Examined : 155520 
  12.  
  13. Total Pages Processed (Data) : 144530 
  14.  
  15. Total Pages Failing (Data) : 0 
  16.  
  17. Total Pages Processed (Index): 52 
  18.  
  19. Total Pages Failing (Index): 0 
  20.  
  21. Total Pages Processed (Other): 1248 
  22.  
  23. Total Pages Processed (Seg) : 0 
  24.  
  25. Total Pages Failing (Seg) : 0 
  26.  
  27. Total Pages Empty : 9690 
  28.  
  29. Total Pages Marked Corrupt : 0 
  30.  
  31. Total Pages Influx : 0 
  32.  
  33. Total Pages Encrypted : 0 
  34.  
  35. Highest block SCN : 3559792 (0.3559792) 

這個工具報告使用的是page作為單位,含義和data block相同。從上面的檢查結果Total Pages Marked Corrupt : 0可以看出文件沒有壞塊。

除了檢查數據文件,這個工具還允許檢查單獨的Segment,這時參數值的格式為<tsn.segfile.segblock>

查看對象的tsn,segfile,segblock屬性:

  1. zx@TEST>select t.ts#,s.header_file,s.header_block 
  2.   2  from v$tablespace t,dba_segments s 
  3.   3  where s.segment_name='T' 
  4.   4  and t.name=s.tablespace_name; 
  5.    
  6.        TS# HEADER_FILE HEADER_BLOCK 
  7. ---------- ----------- ------------ 
  8.          4           4        45834 

從上面的查詢結果可行參數值為4.4.45834。檢查Segment:

  1. [oracle@rhel6 ~]$ dbv userid=system/123456 segment_id=4.4.45834 
  2.    
  3. DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 20:58:33 2017 
  4.    
  5. Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved. 
  6.    
  7. DBVERIFY - Verification starting : SEGMENT_ID = 4.4.45834 
  8.    
  9.    
  10. DBVERIFY - Verification complete 
  11.    
  12. Total Pages Examined         : 8 
  13. Total Pages Processed (Data) : 5 
  14. Total Pages Failing   (Data) : 0 
  15. Total Pages Processed (Index): 0 
  16. Total Pages Failing   (Index): 0 
  17. Total Pages Processed (Other): 2 
  18. Total Pages Processed (Seg)  : 1 
  19. Total Pages Failing   (Seg)  : 0 
  20. Total Pages Empty            : 0 
  21. Total Pages Marked Corrupt   : 0 
  22. Total Pages Influx           : 0 
  23. Total Pages Encrypted        : 0 
  24. Highest block SCN            : 3518579 (0.3518579) 

下面人為創(chuàng)造一個壞塊,用dbv來檢查。

創(chuàng)建一個測試表

  1. zx@TEST>create table bbed (id number,name varchar2(20)) tablespace users; 
  2.    
  3. Table created. 
  4.    
  5. zx@TEST>insert into bbed values(1,'zhaoxu'); 
  6.    
  7. 1 row created. 
  8.    
  9. zx@TEST>commit
  10.    
  11. Commit complete. 

當前數據文件沒有壞塊

  1. [oracle@rhel6 ~]$ dbv file=/u01/app/oracle/oradata/test/users01.dbf 
  2.    
  3. DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 21:03:40 2017 
  4.    
  5. Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved. 
  6.    
  7. DBVERIFY - Verification starting : FILE = /u01/app/oracle/oradata/test/users01.dbf 
  8.    
  9.    
  10. DBVERIFY - Verification complete 
  11.    
  12. Total Pages Examined         : 155520 
  13. Total Pages Processed (Data) : 66397 
  14. Total Pages Failing   (Data) : 0 
  15. Total Pages Processed (Index): 52 
  16. Total Pages Failing   (Index): 0 
  17. Total Pages Processed (Other): 88898 
  18. Total Pages Processed (Seg)  : 0 
  19. Total Pages Failing   (Seg)  : 0 
  20. Total Pages Empty            : 173 
  21. Total Pages Marked Corrupt   : 0 
  22. Total Pages Influx           : 0 
  23. Total Pages Encrypted        : 0 
  24. Highest block SCN            : 3764775 (0.3764775) 

獲取表在文件中的存儲信息

  1. zx@TEST>set serveroutput on 
  2. zx@TEST>declare rfno number; 
  3.   2  rtype number; 
  4.   3  ono number; 
  5.   4  blkno number; 
  6.   5  rowno number; 
  7.   6  rid varchar2(30); 
  8.   7  begin 
  9.   8  select rowid into rid from bbed; 
  10.   9  dbms_rowid.rowid_info(ROWID_IN=>rid,RELATIVE_FNO=>rfno,BLOCK_NUMBER=>blkno,ROW_NUMBER=>rowno,ROWID_TYPE=>rtype,OBJECT_NUMBER=>ono); 
  11.  10  dbms_output.put_line(rfno||','||blkno||','||rowno); 
  12.  11  end
  13.  12  / 
  14. 4,45844,0 
  15.    
  16. PL/SQL procedure successfully completed. 

使用bbed修改塊信息

  1. [oracle@rhel6 bbed]$ bbed parfile=bbed.par 
  2. Password:  
  3.    
  4. BBED: Release 2.0.0.0.0 - Limited Production on Mon May 22 21:17:18 2017 
  5.    
  6. Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved. 
  7.    
  8. ************* !!! For Oracle Internal Use only !!! *************** 
  9.    
  10. BBED> set dba 4,45844 
  11.         DBA             0x0100b314 (16823060 4,45844) 
  12.    
  13. BBED> find /c zhaoxu 
  14.  File: /u01/app/oracle/oradata/test/users01.dbf (4) 
  15.  Block: 45844            Offsets: 8182 to 8191           Dba:0x0100b314 
  16. ------------------------------------------------------------------------ 
  17.  7a68616f 78750106 5873  
  18.    
  19.  <32 bytes per line> 
  20.    
  21. BBED> dump /v dba 4,45844 offset 8182 count 32 
  22.  File: /u01/app/oracle/oradata/test/users01.dbf (4) 
  23.  Block: 45844   Offsets: 8182 to 8191  Dba:0x0100b314 
  24. ------------------------------------------------------- 
  25.  7a68616f 78750106 5873              l zhaoxu..Xs 
  26.    
  27.  <16 bytes per line> 
  28.    
  29. BBED> modify 100 dba 4,45844 
  30. Warning: contents of previous BIFILE will be lost. Proceed? (Y/N) y 
  31.  File: /u01/app/oracle/oradata/test/users01.dbf (4) 
  32.  Block: 45844            Offsets: 8182 to 8191           Dba:0x0100b314 
  33. ------------------------------------------------------------------------ 
  34.  6468616f 78750106 5873  
  35.    
  36.  <32 bytes per line> 
  37.    
  38. BBED> dump /v dba 4,45844 offset 8182 count 32 
  39.  File: /u01/app/oracle/oradata/test/users01.dbf (4) 
  40.  Block: 45844   Offsets: 8182 to 8191  Dba:0x0100b314 
  41. ------------------------------------------------------- 
  42.  6468616f 78750106 5873              l dhaoxu..Xs 
  43.    
  44.  <16 bytes per line> 
  45.    
  46. BBED> exit 

再次使用dbv檢查文件

  1. [oracle@rhel6 bbed]$ dbv file=/u01/app/oracle/oradata/test/users01.dbf 
  2.    
  3. DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 21:18:46 2017 
  4.    
  5. Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved. 
  6.    
  7. DBVERIFY - Verification starting : FILE = /u01/app/oracle/oradata/test/users01.dbf 
  8. Page 45844 is marked corrupt 
  9. Corrupt block relative dba: 0x0100b314 (file 4, block 45844) 
  10. Bad check value found during dbv:  
  11. Data in bad block: 
  12.  type: 6 format: 2 rdba: 0x0100b314 
  13.  last change scn: 0x0000.00397358 seq: 0x1 flg: 0x04 
  14.  spare1: 0x0 spare2: 0x0 spare3: 0x0 
  15.  consistency value in tail: 0x73580601 
  16.  check value in block header: 0x7c2d 
  17.  computed block checksum: 0x1e 
  18.    
  19.    
  20.    
  21. DBVERIFY - Verification complete 
  22.    
  23. Total Pages Examined         : 155520 
  24. Total Pages Processed (Data) : 66396 
  25. Total Pages Failing   (Data) : 0 
  26. Total Pages Processed (Index): 52 
  27. Total Pages Failing   (Index): 0 
  28. Total Pages Processed (Other): 88898 
  29. Total Pages Processed (Seg)  : 0 
  30. Total Pages Failing   (Seg)  : 0 
  31. Total Pages Empty            : 173 
  32. Total Pages Marked Corrupt   : 1 
  33. Total Pages Influx           : 0 
  34. Total Pages Encrypted        : 0 
  35. Highest block SCN            : 3764775 (0.3764775) 

報告一個壞塊,Total Pages Marked Corrupt : 1

再次查詢測試表:

  1. sys@TEST>select * from zx.bbed; 
  2.    
  3.     ID NAME 
  4. ---------- ------------------------------------------------------------ 
  5.      1 zhaoxu 

查詢正常,因為在buffer_cache中緩存了塊,而修改的是文件中的塊。兩個塊現在不一致,清空buffer cache后再次查詢測試表。

  1. zx@TEST>alter system  flush buffer_cache; 
  2.    
  3. System altered. 
  4.    
  5. zx@TEST>select * from bbed; 
  6. select * from bbed 
  7.               * 
  8. ERROR at line 1: 
  9. ORA-01578: ORACLE data block corrupted (file # 4, block # 45844) 
  10. ORA-01110: data file 4: '/u01/app/oracle/oradata/test/users01.dbf' 

查詢報出錯誤ORA-01578。

使用dbv檢查ASM文件中的數據文件,需要指定userid參數

  1. [oracle@rac1 ~]$ dbv file=+DATA/orcl/datafile/users.259.925306091 userid=sys/123456 
  2.    
  3. DBVERIFY: Release 11.2.0.4.0 - Production on Mon May 22 16:48:22 2017 
  4.    
  5. Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved. 
  6.    
  7. DBVERIFY - Verification starting : FILE = +DATA/orcl/datafile/users.259.925306091 
  8.    
  9.    
  10. DBVERIFY - Verification complete 
  11.    
  12. Total Pages Examined         : 640 
  13. Total Pages Processed (Data) : 16 
  14. Total Pages Failing   (Data) : 0 
  15. Total Pages Processed (Index): 2 
  16. Total Pages Failing   (Index): 0 
  17. Total Pages Processed (Other): 593 
  18. Total Pages Processed (Seg)  : 0 
  19. Total Pages Failing   (Seg)  : 0 
  20. Total Pages Empty            : 29 
  21. Total Pages Marked Corrupt   : 0 
  22. Total Pages Influx           : 0 
  23. Total Pages Encrypted        : 0 
  24. Highest block SCN            : 0 (0.0) 
責任編輯:武曉燕 來源: Linux社區(qū)
相關推薦

2018-11-08 14:50:14

2010-07-15 10:47:22

Perl命令行

2010-11-16 11:50:21

oracle命令行登錄

2021-01-05 06:12:38

Tcpdump工具網絡

2020-12-10 16:16:08

工具代碼開發(fā)

2020-12-11 06:44:16

命令行工具開發(fā)

2009-12-24 14:51:39

Linux命令行

2011-01-18 19:11:26

Postfix命令行

2023-06-09 07:45:29

Kuberneteskubectl

2017-05-25 10:32:40

命令linux系統

2023-07-05 08:38:48

GolangGo語言

2013-11-15 09:43:15

JDK工具

2010-07-15 10:58:23

Perl命令行程序

2010-11-24 17:12:17

MySQL命令行

2013-12-09 14:29:13

OpenStack命令行工具API

2010-11-16 11:55:31

Oracle命令行

2021-01-13 05:29:26

命令行

2009-08-11 09:58:22

Linux命令行Linux命令svn命令

2010-02-04 15:17:48

Linux wget

2018-04-03 13:50:27

Linux容器命令行工具
點贊
收藏

51CTO技術棧公眾號