[20190226]測試使用bbed恢復索引.txt

来源:https://www.cnblogs.com/lfree/archive/2019/02/26/10438177.html
-Advertisement-
Play Games

[20190226]測試使用bbed恢復索引.txt--//上午做tab$刪除恢複測試時發現,tab$的索引i_tab1很小.可以嘗試使用bbed解決這個問題.--//首先在普通表上做一個測試看看.1.環境:SCOTT@book> @ ver1PORT_STRING VERSION BANNER x ...


[20190226]測試使用bbed恢復索引.txt

--//上午做tab$刪除恢複測試時發現,tab$的索引i_tab1很小.可以嘗試使用bbed解決這個問題.
--//首先在普通表上做一個測試看看.

1.環境:
SCOTT@book> @ ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

SCOTT@book> create table empy as select * from emp ;
Table created.

SCOTT@book> create index i_empy_empno on empy(empno);
Index created.

SCOTT@book> select rowid,empy.* from empy where rownum=1;
ROWID                   EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO
------------------ ---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
AAAWPZAAEAAAAILAAA       7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20

SCOTT@book> @ rowid AAAWPZAAEAAAAILAAA
    OBJECT       FILE      BLOCK        ROW ROWID_DBA            DBA                  TEXT
---------- ---------- ---------- ---------- -------------------- -------------------- ----------------------------------------
     91097          4        523          0  0x100020B           4,523                alter system dump datafile 4 block 523 ;

SCOTT@book> select HEADER_FILE,HEADER_BLOCK,segment_name from dba_segments where owner=user and segment_name='I_EMPY_EMPNO';
HEADER_FILE HEADER_BLOCK SEGMENT_NAME
----------- ------------ --------------------
          4          530 I_EMPY_EMPNO
--//索引的roor節點在dba=4,531.

2.刪除記錄看看:

SCOTT@book> delete from empy where empno not in (7369);
13 rows deleted.

SCOTT@book> commit ;
Commit complete.

--//僅僅保留1條.並且這條是empy表最小的empno號.

SCOTT@book> alter system checkpoint ;
System altered.

3.先恢復表:
BBED> set dba 4,523
        DBA             0x0100020b (16777739 4,523)


BBED> x /rnccntnnn *kdbr[0]
rowdata[529]                                @8150
------------
flag@8150: 0x2c (KDRHFL, KDRHFF, KDRHFH)
lock@8151: 0x00
cols@8152:    8

col    0[3] @8153: 7369
col    1[5] @8157: SMITH
col    2[5] @8163: CLERK
col    3[3] @8169: 7902
col    4[7] @8173: 1980-12-17 00:00:00
col    5[2] @8181: 800
col    6[0] @8184: *NULL*
col    7[2] @8185: 20
--//這條記錄保留.

BBED> x /rnccntnnn *kdbr[1]
rowdata[486]                                @8107
------------
flag@8107: 0x3c (KDRHFL, KDRHFF, KDRHFD, KDRHFH)
lock@8108: 0x02
cols@8109:    0

--//執行如下生成bbed腳本:
$ seq 1 13 | xargs -I{} echo 'x /rnccntnnn dba 4,523 *kdbr[{}]' | rlbbed | grep -B1 "^lock@" | grep "^flag@.*=0x3c" | cut -d: -f1| cut -d"@" -f2 | xargs -I{} echo assign dba 4,523 offset {}=0x2c
assign dba 4,523 offset 8107=0x2c
assign dba 4,523 offset 8064=0x2c
assign dba 4,523 offset 8023=0x2c
assign dba 4,523 offset 7978=0x2c
assign dba 4,523 offset 7937=0x2c
assign dba 4,523 offset 7896=0x2c
assign dba 4,523 offset 7856=0x2c
assign dba 4,523 offset 7818=0x2c
assign dba 4,523 offset 7775=0x2c
assign dba 4,523 offset 7737=0x2c
assign dba 4,523 offset 7699=0x2c
assign dba 4,523 offset 7660=0x2c
assign dba 4,523 offset 7621=0x2c

--//執行如上腳本,去除刪除標識.

BBED> sum apply
Check value for File 4, Block 523:
current = 0x8c05, required = 0x8c05

BBED> verify
DBVERIFY - Verification starting
FILE = /mnt/ramdisk/book/users01.dbf
BLOCK = 523

Block Checking: DBA = 16777739, Block Type = KTB-managed data block
data header at 0x7f6d56b9427c
kdbchk: the amount of space used is not equal to block size
        used=613 fsc=503 avsp=7451 dtl=8064
Block 523 failed with check code 6110

--//dtl-used-fsc = avsp

BBED> p ktbbh.ktbbhitl[1]._ktbitun._ktbitfsc
sb2 _ktbitfsc                               @86       503

BBED> assign ktbbh.ktbbhitl[1]._ktbitun._ktbitfsc=0
sb2 _ktbitfsc                               @86       0

BBED> sum apply
Check value for File 4, Block 523:
current = 0x8df2, required = 0x8df2

BBED> verify
DBVERIFY - Verification starting
FILE = /mnt/ramdisk/book/users01.dbf
BLOCK = 523

Block Checking: DBA = 16777739, Block Type = KTB-managed data block
data header at 0xe9427c
kdbchk: space available on commit is incorrect
        tosp=7980 fsc=0 stb=0 avsp=7451
Block 523 failed with check code 6111

--//avsp+fsc+stb=tops.

BBED> assign kdbh.kdbhtosp=kdbh.kdbhavsp
sb2 kdbhtosp                                @136      7451

BBED> sum apply
Check value for File 4, Block 523:
current = 0x8fc5, required = 0x8fc5

BBED> verify
DBVERIFY - Verification starting
FILE = /mnt/ramdisk/book/users01.dbf
BLOCK = 523

--//OK, 現在對應塊已經修複.

SCOTT@book> alter system flush buffer_cache;
System altered.

SCOTT@book> select * from empy ;
     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
      7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20
      7499 ALLEN      SALESMAN        7698 1981-02-20 00:00:00       1600        300         30
      7521 WARD       SALESMAN        7698 1981-02-22 00:00:00       1250        500         30
      7566 JONES      MANAGER         7839 1981-04-02 00:00:00       2975                    20
      7654 MARTIN     SALESMAN        7698 1981-09-28 00:00:00       1250       1400         30
      7698 BLAKE      MANAGER         7839 1981-05-01 00:00:00       2850                    30
      7782 CLARK      MANAGER         7839 1981-06-09 00:00:00       2450                    10
      7788 SCOTT      ANALYST         7566 1987-04-19 00:00:00       3000                    20
      7839 KING       PRESIDENT            1981-11-17 00:00:00       5000                    10
      7844 TURNER     SALESMAN        7698 1981-09-08 00:00:00       1500          0         30
      7876 ADAMS      CLERK           7788 1987-05-23 00:00:00       1100                    20
      7900 JAMES      CLERK           7698 1981-12-03 00:00:00        950                    30
      7902 FORD       ANALYST         7566 1981-12-03 00:00:00       3000                    20
      7934 MILLER     CLERK           7782 1982-01-23 00:00:00       1300                    10
14 rows selected.

SCOTT@book> select * from empy where empno in(7499,7369);
     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
      7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20

--//可以發現走索引僅僅找到1條.

SCOTT@book> ANALYZE TABLE empy VALIDATE STRUCTURE CASCADE;
ANALYZE TABLE empy VALIDATE STRUCTURE CASCADE
*
ERROR at line 1:
ORA-01499: table/index cross reference failure - see trace file
--//一般普通表的索引不用恢復,根據表重建就ok了.但是對於sys.tab$的索引不行,這也是做這個測試的原因.

4.恢復索引看看.
BBED> set dba 4,531
        DBA             0x01000213 (16777747 4,531)

BBED> p kd_off
sb2 kd_off[0]                               @132      8032
sb2 kd_off[1]                               @134      0
sb2 kd_off[2]                               @136      8019
sb2 kd_off[3]                               @138      8006
sb2 kd_off[4]                               @140      7993
sb2 kd_off[5]                               @142      7980
sb2 kd_off[6]                               @144      7967
sb2 kd_off[7]                               @146      7954
sb2 kd_off[8]                               @148      7941
sb2 kd_off[9]                               @150      7928
sb2 kd_off[10]                              @152      7915
sb2 kd_off[11]                              @154      7902
sb2 kd_off[12]                              @156      7889
sb2 kd_off[13]                              @158      7877

--//可以發現bbed查看索引有問題,kd_off[0],kd_off[1]看到的偏移是不對的.實際上kd_off偏移從136開始kd_off[2].

BBED> x /rnx *kd_off[2]
rowdata[172]                                @8119
------------
flag@8119:     0x00 (NONE)
lock@8120:     0x00
data key:
col    0[3] @8122: 7369
col    1[6] @8126:  0x01  0x00  0x02  0x0b  0x00  0x00

--//這個表的第一條記錄(最小值),我沒有刪除.empno=7369.

BBED> x /rnx *kd_off[3]
rowdata[159]                                @8106
------------
flag@8106:     0x01 (KDXRDEL)
lock@8107:     0x02
data key:
col    0[3] @8109: 7499
col    1[6] @8113:  0x01  0x00  0x02  0x0b  0x00  0x01
--//對比刪除與不刪除的可以看出.flag不同,刪除的flag=0x01.

$ seq 2 13 | xargs -I{} echo 'x /rnx dba 4,531 *kd_off[{}]' | rlbbed | grep -B1 "^lock@.*:*0x02$" | grep "flag@.*0x01" | cut -d: -f1 | cut -d@ -f2 |xargs -I{} echo assign dba 4,531 offset {}=0x00
assign dba 4,531 offset 8106=0x00
assign dba 4,531 offset 8093=0x00
assign dba 4,531 offset 8080=0x00
assign dba 4,531 offset 8067=0x00
assign dba 4,531 offset 8054=0x00
assign dba 4,531 offset 8041=0x00
assign dba 4,531 offset 8028=0x00
assign dba 4,531 offset 8015=0x00
assign dba 4,531 offset 8002=0x00
assign dba 4,531 offset 7989=0x00
assign dba 4,531 offset 7977=0x00
--//僅僅修改11條,還有2條需要修改標識.

BBED> dump  offset 160 count 4
 File: /mnt/ramdisk/book/users01.dbf (4)
 Block: 531             Offsets:  160 to  163   Dba:0x01000213
---------------------------------------------------------------
 b81eab1e

 <64 bytes per line>

--// 說明: kd_off[13]的偏移量記錄在偏移158,下麵2條記錄的偏移記錄從160算起.
--// b81e 顛倒過來就是  1eb8=7864 , 記錄相對偏移從kdxle算起(當前是100), 7864+100 = 7964
--// ab1e 顛倒過來就是  1eab=7851 , 記錄相對偏移從kdxle算起(當前是100), 7851+100  = 7951

BBED> x /rnx offset 7964
rowdata[17]                                 @7964
-----------
flag@7964:     0x01 (KDXRDEL)
lock@7965:     0x02
data key:
col    0[3] @7967: 7902
col    1[6] @7971:  0x01  0x00  0x02  0x0b  0x00  0x0c

BBED> x /rnx offset 7951
rowdata[4]                                  @7951
----------
flag@7951:     0x01 (KDXRDEL)
lock@7952:     0x02
data key:
col    0[3] @7954: 7934
col    1[6] @7958:  0x01  0x00  0x02  0x0b  0x00  0x0d

--//也就是要補充執行如下:
assign dba 4,531 offset 7964=0x00
assign dba 4,531 offset 7951=0x00

--//執行如下腳本:
--//補充如果你仔細看就可以發現鍵值是按照行目錄排序的.如果有記錄插入,oracle是通過2分法定位插入行目錄的位置,
--//你可以發現後面的偏移不是有序的,這也就是索引的塊內無序,塊間有序,但是如果索引分裂,oracle會重新排序.

assign dba 4,531 offset 8106=0x00
assign dba 4,531 offset 8093=0x00
assign dba 4,531 offset 8080=0x00
assign dba 4,531 offset 8067=0x00
assign dba 4,531 offset 8054=0x00
assign dba 4,531 offset 8041=0x00
assign dba 4,531 offset 8028=0x00
assign dba 4,531 offset 8015=0x00
assign dba 4,531 offset 8002=0x00
assign dba 4,531 offset 7989=0x00
assign dba 4,531 offset 7977=0x00
assign dba 4,531 offset 7964=0x00
assign dba 4,531 offset 7951=0x00

BBED> sum apply
Check value for File 4, Block 531:
current = 0x91b5, required = 0x91b5

BBED> verify
DBVERIFY - Verification starting
FILE = /mnt/ramdisk/book/users01.dbf
BLOCK = 531

Block Checking: DBA = 16777747, Block Type = KTB-managed data block
**** actual free space = 7593 < kdxcoavs = 7787
**** actual rows marked deleted = 0 != kdxlende = 13
---- end index block validation
Block 531 failed with check code 6401


BBED> p kdxle.kdxlende
sb2 kdxlende                                @118      13

BBED> assign  kdxle.kdxlende=0
sb2 kdxlende                                @118      0

BBED> sum apply
Check value for File 4, Block 531:
current = 0x91b8, required = 0x91b8

BBED> verify
DBVERIFY - Verification starting
FILE = /mnt/ramdisk/book/users01.dbf
BLOCK = 531

Block Checking: DBA = 16777747, Block Type = KTB-managed data block
**** actual free space = 7593 < kdxcoavs = 7787
---- end index block validation
Block 531 failed with check code 6401

BBED> p kdxle.kdxlexco.kdxcoavs
sb2 kdxcoavs                                @114      7787

BBED> assign kdxle.kdxlexco.kdxcoavs=7593
sb2 kdxcoavs                                @114      7593

BBED> sum apply
Check value for File 4, Block 531:
current = 0x927a, required = 0x927a

BBED> verify
DBVERIFY - Verification starting
FILE = /mnt/ramdisk/book/users01.dbf
BLOCK = 531

--//OK,現在完全修複了.

3.驗證看看:
SCOTT@book> alter system flush buffer_cache;
System altered.

SCOTT@book> select * from empy where empno in(7499,7369);
     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
      7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20
      7499 ALLEN      SALESMAN        7698 1981-02-20 00:00:00       1600        300         30

--//通過索引能定位行記錄.
SCOTT@book> ANALYZE TABLE empy VALIDATE STRUCTURE CASCADE;
Table analyzed.

--//ANALYZE TABLE empy VALIDATE STRUCTURE CASCADE;一切ok,證明修複沒有任何問題.

總結:
--//使用bbed修複索引有點繁瑣,主要kd_off記錄的偏移不對,從kd_off[2]算起.並且遺漏2條鍵值記錄.



您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • (一)通過vi編輯器來替換。vi/vim 中可以使用 :s 命令來替換字元串。:s/well/good/ 替換當前行第一個 well 為 good:s/well/good/g 替換當前行所有 well 為 good:n,$s/well/good/ 替換第 n 行開始到最後一行中每一行的第一個 wel ...
  • 上章節提到通過netdom join加域並指定對應OU,本章再補充一例現成powershell加域並指定對應OU的腳本,便於大家工作中使用。$PlainPassword = P@ssw0rd$UserName="Administrator"$DomainName="azureyun.com"$Dom... ...
  • 本文收錄在容器技術學習系列文章總目錄 1、configmap 1.1 認識configmap ConfigMap用於保存配置數據的鍵值對,可以用來保存單個屬性,也可以用來保存配置文件。ConfigMap跟secret很類似,但它可以更方便地處理不包含敏感信息的字元串。 1.2 創建configmap ...
  • 前邊我們提到了客戶端如何通過圖形化、netdom 、Powershell方式加域,這裡我們簡單補充下生產環境中如何通過有許可權的用戶賬號加域並指定對應的OU,以防止域策略下發對部分生產伺服器許可權等內容進行修改,本次為大家補充netdom join方式;如果不怕麻煩的話,我們也可以通過圖形化方式先加域不... ...
  • [20190226]刪除tab$記錄的恢復6.txt--//春節前幾天做了刪除tan$記錄的測試,鏈接:http://blog.itpub.net/267265/viewspace-2565245/=> [20190130]刪除tab$記錄的恢復.txthttp://blog.itpub.net/2 ...
  • 雖然前面兩篇已經說了redis的一些配置安裝什麼的,篇幅有點長,可能看完了也不知道怎麼操作,這裡再濃縮一下: 什麼是redis redis完全開源免費的,遵守BSD協議,是一個高性能的非關係型key-value資料庫, redis特點: redis支持數據的持久化,可以將記憶體中的數據保存在磁碟中... ...
  • 筆記記錄自林曉斌(丁奇)老師的《MySQL實戰45講》 3) --事務隔離,為什麼你改了我還看不見? 簡單來說,事務就是要保證一組數據操作,要麼全部成功,要麼全部失敗。在MySQL中,事務支持是在引擎層實現的。但並不是所有的引擎都支持事務,這也是MyISAM被InnoDB取代的重要原因之一。 本篇內 ...
  • MySql中當前時間,不能直接使用Date.Now傳輸。猜測:這個可能跟伺服器地理位置有關係;一般國外的伺服器時間展示位:月/日/年; 國內通常為:年-月-日;猜測,使用的時候應註意檢查 如下麵的代碼,可能會導致查詢數據不准:應改為:Date.Now.ToString("yyyy-MM-dd HH: ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...