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

怎么计算出正确的checksum值?

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

怎么计算出正确的checksum值?

1)创建一个测试表

SQL> create table test (id int, name varchar2(10));

 

Table created.

 

SQL> insert into test values(1,'AAAAA');

 

1 row created.

SQL> commit;

 

Commit complete.

 

SQL> select dbms_rowid.ROWID_RELATIVE_FNO(rowid) file#,dbms_rowid.ROWID_BLOCK_NUMBER(rowid) blk# from test;

 

     FILE#       BLK#

---------- ----------

         4        284

 

通过BBED查看当前的CHECKSUM值

[oracle@Mysql ~]$ bbed

 

BBED: Release 2.0.0.0.0 - Limited Production on Fri May 25 00:54:11 2018

 

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

 

************* !!! For Oracle Internal Use only !!! ***************

 

BBED> set file 4 block 284

        FILE#           4

        BLOCK#          284

 

BBED> sum

Check value for File 4, Block 284:

current = 0xf9ff, required = 0xf9ff

 

把284号数据块dump出来。

[oracle@Mysql ~]$ dd if=/u01/app/oracle/oradata/dsidb/users01.dbf of=/tmp/test.dd count=1 skip=284 bs=8192

1+0 records in

1+0 records out

8192 bytes (8.2 kB) copied, 0.000435816 s, 18.8 MB/s

 

我们使用UE编辑器打开test.dd数据块

然后把C1 02改成C1 03

 

然后把test.dd数据块copy回去

[oracle@Mysql tmp]$ dd if=/tmp/test.dd of=/u01/app/oracle/oradata/dsidb/users01.dbf count=1 seek=284 bs=8192 conv=notrunc

1+0 records in

1+0 records out

8192 bytes (8.2 kB) copied, 0.000339993 s, 24.1 MB/s

 

 

然后重启一下数据库

SQL> startup force;

ORACLE instance started.

 

Total System Global Area  588746752 bytes

Fixed Size                  2230592 bytes

Variable Size             201328320 bytes

Database Buffers          377487360 bytes

Redo Buffers                7700480 bytes

Database mounted.

Database opened.

 

SQL> conn scott/oracle

Connected.

SQL> select * from test;

select * from test

              *

ERROR at line 1:

ORA-01578: ORACLE data block corrupted (file # 4, block # 284)

ORA-01110: data file 4: '/u01/app/oracle/oradata/dsidb/users01.dbf'

 

可以看到数据库查询表test报错,我们再看一下数据库日志。

2018-05-25 01:16:29.248000 +08:00

Errors in file /u01/app/oracle/diag/rdbms/dsidb/dsidb/trace/dsidb_ora_10666.trc  (incident=102183):

ORA-01578: ORACLE data block corrupted (file # 4, block # 284)

ORA-01110: data file 4: '/u01/app/oracle/oradata/dsidb/users01.dbf'

Incident details in: /u01/app/oracle/diag/rdbms/dsidb/dsidb/incident/incdir_102183/dsidb_ora_10666_i102183.trc

Sweep [inc][102182]: completed

Hex dump of (file 4, block 284) in trace file /u01/app/oracle/diag/rdbms/dsidb/dsidb/incident/incdir_102182/dsidb_m000_10668_i102182_a.trc

Corrupt block relative dba: 0x0100011c (file 4, block 284)

Bad check value found during validation

Data in bad block:

 type: 6 format: 2 rdba: 0x0100011c

 last change scn: 0x0000.003ffe2d seq: 0x1 flg: 0x06

 spare1: 0x0 spare2: 0x0 spare3: 0x0

 consistency value in tail: 0xfe2d0601

 check value in block header: 0xf9ff

 computed block checksum: 0x100

 

可以看到文件头上的check value值为0xf9ff,计算的check sum值为0x100

 

然后我们再使用BBED去sum一下这个数据块,可以看到,当前check value的值为f9ff,而需要的值为f8ff

[oracle@Mysql ~]$ bbed

 

BBED: Release 2.0.0.0.0 - Limited Production on Fri May 25 01:18:44 2018

 

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

 

************* !!! For Oracle Internal Use only !!! ***************

 

BBED> set file 4 block 284

        FILE#           4

        BLOCK#          284

 

BBED> sum

Check value for File 4, Block 284:

current = 0xf9ff, required = 0xf8ff

 

我们根据 0xf9ff与0x100计算一下当前block正常的checksum值应该是多少。

F9FF= 1111 1001 1111 1111

100=  0000 0001 0000 0000

根据异或算法原理,这里很容易可以看出oracle计算出来的正确的checksum值应该是:  1111 1000 1111 1111, 也就是f8ff

 

好了,我们这里如法炮制再改一次上述block的checksum值,即将上述block的checksum值改为f8 ff

 

我们先verify一下

BBED> verify

DBVERIFY - Verification starting

FILE = /u01/app/oracle/oradata/dsidb/users01.dbf

BLOCK = 284

 

Block 284 is corrupt

Corrupt block relative dba: 0x0100011c (file 0, block 284)

Bad check value found during verification

Data in bad block:

 type: 6 format: 2 rdba: 0x0100011c

 last change scn: 0x0000.003ffe2d seq: 0x1 flg: 0x06

 spare1: 0x0 spare2: 0x0 spare3: 0x0

 consistency value in tail: 0xfe2d0601

 check value in block header: 0xf9ff

 computed block checksum: 0x100

 

 

DBVERIFY - Verification complete

 

Total Blocks Examined         : 1

Total Blocks Processed (Data) : 0

Total Blocks Failing   (Data) : 0

Total Blocks Processed (Index): 0

Total Blocks Failing   (Index): 0

Total Blocks Empty            : 0

Total Blocks Marked Corrupt   : 1

Total Blocks Influx           : 0

 

 

BBED> sum

Check value for File 4, Block 284:

current = 0xf9ff, required = 0xf8ff

 

BBED> sum

Check value for File 4, Block 284:

current = 0xf9ff, required = 0xf8ff

 

BBED> modify /x 0xf8ff offset 16

Warning: contents of previous BIFILE will be lost. Proceed? (Y/N) y

 File: /u01/app/oracle/oradata/dsidb/users01.dbf (4)

 Block: 284              Offsets:   16 to  527           Dba:0x0100011c

------------------------------------------------------------------------

 f8ff0000 01000000 fa2a0100 2cfe3f00 00000000 02003200 18010001 1d000900

 a0000000 ba040002 4d001100 01200000 2dfe3f00 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00010100 ffff1400 8c1f781f

 781f0000 01008c1f ffff3200 a0046e04 6e040000 1000c01d 961c7b1b b9190418

 50167a14 9812f110 4b0f830d ba0bde09 29087606 a0040000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000

 

 <32 bytes per line>

 

BBED> sum apply

Check value for File 4, Block 284:

current = 0xf8ff, required = 0xf8ff

 

 

然后再次verify,可以看到,已经不报坏块了。

BBED> verify

DBVERIFY - Verification starting

FILE = /u01/app/oracle/oradata/dsidb/users01.dbf

BLOCK = 284

 

 

DBVERIFY - Verification complete

 

Total Blocks Examined         : 1

Total Blocks Processed (Data) : 1

Total Blocks Failing   (Data) : 0

Total Blocks Processed (Index): 0

Total Blocks Failing   (Index): 0

Total Blocks Empty            : 0

Total Blocks Marked Corrupt   : 0

Total Blocks Influx           : 0

 

 

BBED> sum

Check value for File 4, Block 284:

current = 0xf8ff, required = 0xf8ff

 

数据也可以正常返回了。

SQL> select * from test;

 

        ID NAME

---------- ----------

         2 AAAAA

 

 

 

2.重现数据块内空间计算错误?(详细的实验操作步骤,BBED工具verify如下命令提示)

BBED>verify

 

kdbchk:the amount of space used is not equal to block size

Total Blocks Failing(Data)

 

SQL> create table t2 (id int,name varchar2(10));

 

Table created.

 

SQL> insert into t2 values(1,'AAAAA');

 

1 row created.

 

SQL> commit;

 

Commit complete.

 

 

SQL> alter system flush buffer_cache;

 

System altered.

 

SQL> select dbms_rowid.rowid_relative_fno(rowid) file#,dbms_rowid.rowid_block_number(rowid) blk# from t2;

 

     FILE#       BLK#

---------- ----------

         4        220

 

 

SQL> delete from t2;

 

1 row deleted.

 

SQL> alter system flush buffer_cache;

 

System altered.

 

 

BBED> set file 4 block 220

        FILE#           4

        BLOCK#          220

 

BBED> map

 File: /u01/app/oracle/oradata/dsidb/users01.dbf (4)

 Block: 220                                   Dba:0x010000dc

------------------------------------------------------------

 KTB Data Block (Table/Cluster)

 

 struct kcbh, 20 bytes                      @0      

 

 struct ktbbh, 72 bytes                     @20     

 

 struct kdbh, 14 bytes                      @100    

 

 struct kdbt[1], 4 bytes                    @114    

 

 sb2 kdbr[1]                                @118    

 

 ub1 freespace[8055]                        @120    

 

 ub1 rowdata[13]                            @8175   

 

 ub4 tailchk                                @8188   

 

 

BBED> p rowdata

ub1 rowdata[0]                              @8175     0x3c

ub1 rowdata[1]                              @8176     0x02

ub1 rowdata[2]                              @8177     0x02

ub1 rowdata[3]                              @8178     0x02

ub1 rowdata[4]                              @8179     0xc1

ub1 rowdata[5]                              @8180     0x02

ub1 rowdata[6]                              @8181     0x06

ub1 rowdata[7]                              @8182     0x41

ub1 rowdata[8]                              @8183     0x41

ub1 rowdata[9]                              @8184     0x41

ub1 rowdata[10]                             @8185     0x41

ub1 rowdata[11]                             @8186     0x41

ub1 rowdata[12]                             @8187     0x0a

 

BBED> modify /x 2c offset 8175

 File: /u01/app/oracle/oradata/dsidb/users01.dbf (4)

 Block: 220              Offsets: 8175 to 8191           Dba:0x010000dc

------------------------------------------------------------------------

 2c020202 c1020641 41414141 0a010621 59

 

 <32 bytes per line>

 

BBED> sum apply

Check value for File 4, Block 220:

current = 0x1f3f, required = 0x1f3f

 

BBED> verify

DBVERIFY - Verification starting

FILE = /u01/app/oracle/oradata/dsidb/users01.dbf

BLOCK = 220

 

Block Checking: DBA = 16777436, Block Type = KTB-managed data block

data header at 0x24d9064

kdbchk: the amount of space used is not equal to block size

        used=33 fsc=11 avsp=8055 dtl=8088

Block 220 failed with check code 6110

 

DBVERIFY - Verification complete

 

Total Blocks Examined         : 1

Total Blocks Processed (Data) : 1

Total Blocks Failing   (Data) : 1

Total Blocks Processed (Index): 0

Total Blocks Failing   (Index): 0

Total Blocks Empty            : 0

Total Blocks Marked Corrupt   : 0

Total Blocks Influx           : 0

Message 531 not found;  product=RDBMS; facility=BBED

 

 

BBED> p kdbh

struct kdbh, 14 bytes                       @100    

   ub1 kdbhflag                             @100      0x00 (NONE)

   sb1 kdbhntab                             @101      1

   sb2 kdbhnrow                             @102      1

   sb2 kdbhfrre                             @104     -1

   sb2 kdbhfsbo                             @106      20

   sb2 kdbhfseo                             @108      8075

   sb2 kdbhavsp                             @110      8055

   sb2 kdbhtosp                             @112      8068

免责声明:

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

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

怎么计算出正确的checksum值?

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

下载Word文档

猜你喜欢

php怎么正确计算中文字符串的长度

今天小编给大家分享一下php怎么正确计算中文字符串的长度的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、PHP中字符串长度
2023-07-05

C++的运算符怎么正确使用

今天小编给大家分享一下C++的运算符怎么正确使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前言运算符的作用:用于执行代码
2023-06-29

jquery怎么在IE8中正确设置text的值

这篇文章主要介绍“jquery怎么在IE8中正确设置text的值”,在日常操作中,相信很多人在jquery怎么在IE8中正确设置text的值问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”jquery怎么在IE
2023-07-06

怎么为Edm.DateTime的OData参数指定正确格式的值

这篇文章主要讲解了“怎么为Edm.DateTime的OData参数指定正确格式的值”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么为Edm.DateTime的OData参数指定正确格式的值
2023-06-03

怎么用VBS精确计算2的100次方

这篇文章主要介绍了怎么用VBS精确计算2的100次方,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。既然Python可以计算2的100次方,那么我就要用VBS实现。不过这个效率
2023-06-08

java怎么计算数组的平均值

要计算一个数组的平均值,可以使用以下Java代码:public class AverageCalculator {public static void main(String[] args) {int[] array = {10, 20,
java怎么计算数组的平均值
2024-03-14

win10的计算器怎么调出来

这篇“win10的计算器怎么调出来”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“win10的计算器怎么调出来”文章吧。win
2023-06-30

linux中shell怎么计算变量的数值

这期内容当中小编将会给大家带来有关linux中shell怎么计算变量的数值,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、expr命令a=123expr $a + 10
2023-06-09

使用java怎么计算数组的最大值

本篇文章给大家分享的是有关使用java怎么计算数组的最大值,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、We
2023-06-14

java怎么计算字符串表达式的值

在Java中,你可以使用ScriptEngine类来计算字符串表达式的值。下面是一个简单的例子:import javax.script.ScriptEngine;import javax.script.ScriptEngineManag
2023-10-23

r语言怎么计算数组的平均值

在R语言中,可以使用mean()函数来计算数组的平均值。例如,对一个包含数字的数组进行平均值计算可以这样做:# 创建一个包含数字的数组nums <- c(1, 2, 3, 4, 5)# 计算数组的平均值average <- mean(
r语言怎么计算数组的平均值
2024-03-06

crontab脚本错误日志怎么正确的输出写入到文件

这篇文章主要介绍“crontab脚本错误日志怎么正确的输出写入到文件”,在日常操作中,相信很多人在crontab脚本错误日志怎么正确的输出写入到文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”crontab
2023-07-05

怎么使用Java计算修改文件的MD5值

这篇文章主要讲解了“怎么使用Java计算修改文件的MD5值”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用Java计算修改文件的MD5值”吧!什么是 MD5 ?MD5(Message
2023-07-05

怎么在python中使用defaultdict计算键值的和

这篇文章将为大家详细讲解有关怎么在python中使用defaultdict计算键值的和,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python可以做什么Python是一种编程语言,内置了许
2023-06-14

Python怎么计算图片数据集的均值方差

本文小编为大家详细介绍“Python怎么计算图片数据集的均值方差”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python怎么计算图片数据集的均值方差”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Python批
2023-06-30

Win10出现跟这台计算机连接的一个usb设备运行不正常怎么办

当Windows 10提示与计算机连接的USB设备运行不正常时,你可以尝试以下方法解决问题:1. 重新连接设备:将USB设备从计算机中拔出,稍等片刻后再重新插入USB端口。有时候设备连接不良或者USB接口松动会导致设备运行异常。2. 检查驱
2023-09-09

编程热搜

目录