首页 > 其他分享 >[20230427]bbed sum apply问题2.txt

[20230427]bbed sum apply问题2.txt

时间:2023-04-27 10:44:06浏览次数:38  
标签:ramdisk 20230427 log -- sum mnt book txt redo02

[20230427]bbed sum apply问题2.txt

--//使用bbed修改数据块时,最后总要sum apply改写校验和,但是修改redo文件是一个例外,sum apply不会修改.
--//通过例子说明:

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

2.测试环境建立:
SCOTT@book> create table deptx  as select * from dept ;
Table created.

SCOTT@book> select rowid,deptx.* from deptx where rownum=1;
ROWID                    DEPTNO DNAME          LOC
------------------ ------------ -------------- -------------
AAAWF/AAEAAAAObAAA           10 ACCOUNTING     NEW YORK

SCOTT@book> @ rowid AAAWF/AAEAAAAObAAA
      OBJECT         FILE        BLOCK          ROW ROWID_DBA            DBA                  TEXT
------------ ------------ ------------ ------------ -------------------- -------------------- ----------------------------------------
       90495            4          923            0  0x100039B           4,923                alter system dump datafile 4 block 923 ;

SCOTT@book> alter system checkpoint;
System altered.

SCOTT@book> alter system archive log current ;
System altered.

SCOTT@book> @ logfile
GROUP# STATUS     TYPE       MEMBER                          IS_ GROUP# THREAD# SEQUENCE#       BYTES BLOCKSIZE MEMBERS ARC STATUS          FIRST_CHANGE# FIRST_TIME                    NEXT_CHANGE# NEXT_TIME
------ ---------- ---------- ------------------------------- --- ------ ------- --------- ----------- --------- ------- --- ---------- ------------------ ------------------- ---------------------- -------------------
     1            ONLINE     /mnt/ramdisk/book/redo01.log    NO       1       1       734    52428800       512       1 YES ACTIVE            13277809855 2023-04-27 06:00:16            13277826041 2023-04-27 09:47:54
     2            ONLINE     /mnt/ramdisk/book/redo02.log    NO       2       1       735    52428800       512       1 NO  CURRENT           13277826041 2023-04-27 09:47:54        281474976710655
     3            ONLINE     /mnt/ramdisk/book/redo03.log    NO       3       1       733    52428800       512       1 YES INACTIVE          13277772888 2023-04-26 22:00:09            13277809855 2023-04-27 06:00:16
     4            STANDBY    /mnt/ramdisk/book/redostb01.log NO
     5            STANDBY    /mnt/ramdisk/book/redostb02.log NO
     6            STANDBY    /mnt/ramdisk/book/redostb03.log NO
     7            STANDBY    /mnt/ramdisk/book/redostb04.log NO
7 rows selected.
--//当前在线日志是 /mnt/ramdisk/book/redo02.log.

3.修改数据块产生日志:
SCOTT@book> update deptx set dname = 'zyxabcde' where deptno=10;
1 row updated.

SCOTT@book> commit ;
Commit complete.

SCOTT@book> alter system archive log current ;
System altered.

$ strings -t d /mnt/ramdisk/book/redo02.log | grep  zyxabcde
  65716 zyxabcde

--//偏移在65716处,redo块大小512,65716/512= 128.3515625,也就是在128块处.
--//块内偏移在65716-128*512 = 180.
--//128*512 = 65536

4.bbed查看:
BBED> info all
 File#  Name                                    Size(blks)
 -----  ----                                    ----------
     1  /mnt/ramdisk/book/system01.dbf                   0
     2  /mnt/ramdisk/book/sysaux01.dbf                   0
     3  /mnt/ramdisk/book/undotbs01.dbf                  0
     4  /mnt/ramdisk/book/users01.dbf                    0
     5  /mnt/ramdisk/book/example01.dbf                  0
     6  /mnt/ramdisk/book/tea01.dbf                      0
     7  /mnt/ramdisk/book/mssm01.dbf                     0
   101  /mnt/ramdisk/book/control01.ctl                  0
   102  /mnt/ramdisk/book/control02.ctl                  0
   201  /mnt/ramdisk/book/temp01.dbf                     0
   501  /mnt/ramdisk/book/redo01.log                     0
   502  /mnt/ramdisk/book/redo02.log                     0
   503  /mnt/ramdisk/book/redo03.log                     0
   504  /mnt/ramdisk/book/redostb01.log                  0

BBED> set dba 502,128
        DBA             0x7d800080 (2105540736 502,128)

BBED> p chkval_kcbh
ub2 chkval_kcbh                             @16       0x01f0
--//当前chkval_kcbh=0x01f0.
        
BBED> dump /v offset 0 count 512
 File: /mnt/ramdisk/book/redo02.log (502)
 Block: 128     Offsets:    0 to  511  Dba:0x7d800080
-------------------------------------------------------
 01220000 80000000 df020000 10805e88 l ."......?....^.
 f0010000 0d010300 748c6b17 0100ff01 l ?......t.k.....
 ~~~~--//checksum.
 80018001 80018001 00000100 01000000 l ................
 01000000 0a018001 738c6b17 03008001 l ........s.k.....
 80018001 802c004e 758c6b17 03000000 l .....,.Nu.k.....
 bb76aa43 0b050100 04000100 9b030001 l 籿狢............
 988b6b17 03004000 02007f61 0a001800 l [email protected]....
 1d000200 08001800 010dd982 00000000 l ..........?....
 0a001900 b4530000 fd07c000 22100500 l ....碨..??"...
 9b030001 9a030001 fa120501 0200ffff l ........?......
 2c020c00 00000301 feff0000 00000000 l ,.......?......
 01000000 7a797861 62636465 05022300 l ....zyxabcde..#.
 0300ffff 1001c000 e48b6b17 0300c000 l ......??k...?
 0100ffff 04002000 19000100 b4530000 l ...... .....碨..
 fd07c000 22100500 12009000 00102200 l ??".........".
 00000000 00000000 05042300 0300ffff l ..........#.....
 1001c000 748c6b17 0300041b 0100ffff l ..?t.k.........
 08001400 10000400 19000000 b4530000 l ............碨..
 00000000 09000000 02000000 fd07c000 l ............??
 22100500 0300441d 00000000 bad44964 l ".....D.....涸Id
 05012400 0300ffff fd07c000 e38b6b17 l ..$.....???k.
 03000000 0100ffff 0e001400 4c000800 l ............L...
 1d000200 0a000000 9000d61d 12000100 l ..........?....
 0a001900 b4530000 22100500 7f610100 l ....碨.."....a..
 7f610100 04000000 00000000 0b011900 l .a..............
 080c0100 00000000 fd07c000 22100400 l ........??"...
 9e876b17 03006681 a0876b17 0300c000 l ..k...f.?k...?
 4e032900 fb8b6b17 03000000 fa07c000 l N.).?k.....??
 00000000 53000000 030d6b17 03000000 l ....S.....k.....
 9b030001 9a030001 fa120501 0200ffff l ........?......
 2c000c00 00000301 02000000 00000000 l ,...............
 01000000 4143434f 554e5449 4e470000 l ....ACCOUNTING..
 <16 bytes per line>

BBED> dump /v offset 180 count 8
 File: /mnt/ramdisk/book/redo02.log (502)
 Block: 128     Offsets:  180 to  187  Dba:0x7d800080
-------------------------------------------------------
 7a797861 62636465                   l zyxabcde
 <16 bytes per line>

BBED> modify /c y offset 180
Warning: contents of previous BIFILE will be lost. Proceed? (Y/N) y
 File: /mnt/ramdisk/book/redo02------------------------------------
 79797861 62636465
 <16 bytes per line>

BBED> dump /v offset 180 count 8
 File: /mnt/ramdisk/book/redo02.log (502)
 Block: 128     Offsets:  180 to  187  Dba:0x7d800080
-------------------------------------------------------
 79797861 62636465                   l yyxabcde

 <16 bytes per line>

BBED> sum
Check value for File 502, Block 128:
current = 0x01f0, required = 0x01f0
--//你可以发现checksum并没有发生变化.也是就是通过bbed sum apply无法修改redo文件的checksum.

BBED> sum apply
Check value for File 502, Block 128:
current = 0x01f0, required = 0x01f0
--//sum apply也没有变化.

$ xxd -c16 -g 2 -s 65536 -l 512 /mnt/ramdisk/book/redo02.log | cut -c10-48 | xor.sh | grep result
xor result: 300

--//不是0,说明修改不正确.

BBED> assign chkval_kcbh=0x0
ub2 chkval_kcbh                             @16       0x0000

$ xxd -c16 -g 2 -s 65536 -l 512 /mnt/ramdisk/book/redo02.log | cut -c10-48 | xor.sh | grep result
xor result: F301

--//可以看出正确的值是0x01F3(注意大小头问题).

BBED> assign chkval_kcbh=0x01F3
ub2 chkval_kcbh                             @16       0x01f3

$ xxd -c16 -g 2 -s 65536 -l 512 /mnt/ramdisk/book/redo02.log | cut -c10-48 | xor.sh | grep result
xor result: 0

--//ok这样才修改正确.
--//之所以有这个测试,因为http://www.killdb.com/2023/04/17/的测试.
--//理论上如果修改redo文件正确,无法通过链接测试模拟出ORA-00312错误的.对方的测试修改块的检查和存在问题.

--//另外一点通过bbed读取这类块要小心,实际上结构不一定正确.也许早期redo文件读取是正确的.

BBED> map
 File: /mnt/ramdisk/book/redo02.log (502)
 Block: 128                                   Dba:0x7d800080
------------------------------------------------------------
 Undo Segment Header
 struct kcbh, 20 bytes                      @0
 struct ktect, 44 bytes                     @20
 struct ktetb[16778139], 134225112 bytes    @64
 struct ktuxc, 104 bytes                    @404
 struct ktuxe[0], 0 bytes                   @508
 ub4 tailchk                                @508

--//bbed把它当作Undo Segment Header.ktetb的结构也不可能这么大.

BBED> dump /v offset 508 count 4
 File: /mnt/ramdisk/book/redo02.log (502)
 Block: 128     Offsets:  508 to  511  Dba:0x7d800080
-------------------------------------------------------
 4e470000                            l NG..
 <16 bytes per line>
--//里面的NG实际上ACCOUNTING的一部分,根本不是普通数据块里面的tailchk.

4.后记:
--//但是我的修改无法通过validate.
SCOTT@book> alter system dump logfile '/mnt/ramdisk/book/redo02.log' validate;
alter system dump logfile '/mnt/ramdisk/book/redo02.log' validate
*
ERROR at line 1:
ORA-00399: corrupt change description in redo log
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
ORA-00353: log corruption near block 128 change 13277826164 time 04/27/2023 09:49:47
ORA-00334: archived log: '/mnt/ramdisk/book/redo02.log'

--//如果我修改回来,validate没有任何问题:
BBED> modify /c z offset 180
 File: /mnt/ramdisk/book/redo02------------------------------------
 7a797861

 <16 bytes per line>

BBED> assign chkval_kcbh=0x01f0
ub2 chkval_kcbh                             @16       0x01f0

SCOTT@book> alter system dump logfile '/mnt/ramdisk/book/redo02.log' validate;
System altered.

5.补充:
--//xor.sh脚本可以从这里下载: http://blog.itpub.net/267265/viewspace-2134945/
--//我脚本里面还使用logic.bc,可以wget http://phodd.net/gnu-bc/code/logic.bc
--//http://phodd.net/gnu-bc/index.html#logic



标签:ramdisk,20230427,log,--,sum,mnt,book,txt,redo02
From: https://www.cnblogs.com/lfree/p/17358268.html

相关文章

  • B. Sum of Two Numbers - 贪心+思维+构造
    题意:给定一个整数n,输出x,y满足以下要求:1.x+y=n2.x的每一位上的数加在一起的数位和和y的数位和相差不超过1.分析:从高位开始依次遍历,将其平均分给x和y,奇数剩余的1由x和y轮流加上。代码:#include<bits/stdc++.h>#defineendl'\n'usingnamespacestd;......
  • 【ABAQUS&Composite】composite layerup Manager从txt导入铺层信息
    ABAQUS在复合材料建模方面自由度是比较高的。官方提供了两个工具:ABAQUS/CAE中的CompositeLayupManagerABAQUS/CAE的plugin:CompositesModeler(需要ABAQUS2019以上)abaqus的compositelayupmanager做单个铺层方案的时候很方便。但是如果做多个铺层方案,就比较麻烦。比如我......
  • 勇士召唤Summon Quest一款mac冒险游戏 中文版
    SummonQuest是一款卡牌收集类的手机游戏,玩家需要在游戏中收集各种强力的卡牌,并组建自己的队伍来进行战斗。游戏采用了即时战斗的方式,玩家需要根据卡牌的属性和技能来制定最佳策略,战胜对手。游戏特色:卡牌收集:SummonQuest拥有数百张不同类型的卡牌,每个卡牌都有独特的属性和技能,玩家......
  • 服务器断电后启动失败报错:Generating /run/initramfs/rdsosreport.txt
    一、现象服务器断电,然后启动时发现起不来,连接显示器发现报错,如下所示: 原因:一般是服务器突然断电导致文件损坏所致,只要修复回去就好二、解决过程2.1寻找/dev/*-root文件说明: /dev/mapper目录下一般有三个文件,其中 centos-root是我们需要修复的。有些服务器的文件名称......
  • sumOfNegatives
    Countofpositives/sumofnegativesGivenanarrayofintegers.Returnanarray,wherethefirstelementisthecountofpositivesnumbersandthesecondelementissumofnegativenumbers.0isneitherpositivenornegative.Iftheinputisanemptyar......
  • 搜狗细胞词库处理代码(可用于scel转txt)
    今天先贴个简单代码,稍后再详细叙述…… 基于QT实现,主要是考虑Unicode字符处理的方便,可以稍加处理用于C或C++语言。 //取连续两字节,转换为short类型的值,字节顺序是低字节-高字节inlineunsignedshortGetUShort(QByteArray&fData,intstartPos){unsignedcharlow=fData......
  • 读取指定路径 .txt 十六进制文件
    filepath='C:\Desktop\2023-04-11-10-21-42_1.txt';fid=fopen(filepath,'r');data='1';N=0;while(0==strcmp('',data))data=fscanf(fid,'%s',1);if(0==strcmp('',data))......
  • Python生成requirements.txt方法
    Python生成requirements.txt方法 requirements.txt可以通过pip命令自动生成和安装,这种情况更适用于此项目是单独的虚拟python环境,生成requirements.txt文件。安装requirements.txt依赖:pipinstall-rrequirements.txt1.方法1:生成requirements.txt文件pipfreeze>re......
  • Codeforces Round 689 (Div. 2, based on Zed Code Competition)D.Divide and Summari
    题意:我们给定包含n个正整数的数组,我们可以对这个数组执行一些操作之后,可以让数组内元素的和成为我们想要的数。我们对数组的执行操作一共分为三个步骤,第一个步骤是我们首先计算出数组的中间值mid。这里mid的定义不是中位数也不是均值,而是最大值和最小值的均值。也就是mid=(min......
  • AtCoder Beginner Contest 283 Ex Popcount Sum
    洛谷传送门AtCoder传送门记录一下这个神奇的套路。首先有\(\operatorname{popcount}(n)=n-\sum\limits_{i=1}^{\infty}\left\lfloor\frac{n}{2^i}\right\rfloor\)。证一下:\[\operatorname{popcount}(n)=\sum\limits_{i=0}^{\infty}\left\lfloor\dfrac{n}{2^i}\right......