安装ORACLE BBED 工具

如果自己搞不定可以找诗檀软件专业ORACLE数据库修复团队成员帮您恢复!

诗檀软件专业数据库修复团队

服务热线 : 13764045638    QQ号:47079569    邮箱:service@parnassusdata.com

 

如果你能在块级直接读取并操作数据会怎样? Oracle提供这样一个工具能做到这些,但你必须自己建立它。块浏览器和编辑器工具,简称BBED,是你在Oracle数据库内读取数据块内容的通行证。你可以用BBED做什么? 你可以:

  • 更改数据
  • 恢复受损的或删除的数据
  • 修改文件头
  • 损坏块并修复坏块

修改数据的能力就是听起来这样的。你可以在任何地方更改任何数据。这意味着什么?这也意味着你可以更改密码- 任何密码。例如,您可以更改sys的口令。

删除一个行,但需要将其恢复?当您或用户删除数据时,数据怎么了?具体来说,数据真的丢了,还是发生了别的事?答案是发生了别的事。 Oracle将该行(或几行)标记为删除,以制造可用空间供将来使用。例如,在DOS中使用文件,当一个文件被删除时,文件名的第一个字符被改变,文件隐藏到正常的“目录”列表。恢复工具可以用来显示已删除的文件。你唯一的工作就是找出丢失的第一个字符。 在Oracle中使用 BBED恢复数据与此事大致相同 – 你只需要找到删除的行的位置,并重设一些标志,使该行再度活跃(假设该行还没有被覆盖)。

在更大的规模上,同样类型的恢复可以使用数据文件来完成。在文件头(文件头块)的内部设置值,可以使旧文件成为当前数据库的一部分。

该BBED工具可以让你有能力损坏块,并修复坏块(重设损坏块标记)。为此目的使用BBED,虽然有趣但不实际,因为有更好的(即,更成熟的,获批准的)方法来修复损坏块。但是,如果你想损坏块并检测你的RMAN技能,这将是一个相当快的方法来设置该实验室环境。

所有上述的一切无需访问数据库进行登录或具有活性实例运行 (除了RMAN恢复)就可以完成。换句话说,如果有人访问BBED并访问你的数据文件,这个人可以访问你数据库中的一切。 一切。如果这还没能说服你保护你的Oracle数据文件,禁止未经授权的用户,你还要怎样呢?

安装 bbed

你是在哪里,怎样得到BBED的?在UNIX中,Oracle 会给你创建该工具所需的信息。无需使bbed变成像exp or sqlplus那样活跃的可执行文件。在Windows上旧版本的Oracle中,可执行文件已安装好可供使用,但现在的版本不是这样。甚至无需成为RDBMS安装就可得到BBED.EXE(在Windows上它是如何命名的)。使用一个Oracle8i客户端安装,BBED.EXE默认安装在 $ORACLE_HOME/bin 。

在UNIX上的32位安装(指所有的* NIX变种),请在$ORACLE_HOME/rdbms/lib下找两个目标文件:sbbdpt.o和ssbbded.o。在64位安装,文件将在lib32目录下。

[oracle] ls -la *bb*.o

-rw-r–r–    1 oracle   dba          1160 Nov 18  2003 sbbdpt.o

-rw-r–r–    1 oracle   dba           848 Nov 18  2003 ssbbded.o

要新建或创造可执行文件,使用如下所示的make命令。

[oracle] make -f ins_rdbms.mk $ORACLE_HOME/rdbms/lib/bbed

make命令的示例输出如下所示。

Linking BBED utility (bbed)

 

rm -f /u001/app/oracle/ora904/rdbms/lib/bbed

 

gcc -o /u001/app/oracle/ora904/rdbms/lib/bbed -L/u001/app/oracle/ora904/rdbms/lib/

-L/u001/app/oracle/ora904/lib/  /u001/app/oracle/ora904/lib/s0main.o

/u001/app/oracle/ora904/rdbms/lib/ssbbded.o

/u001/app/oracle/ora904/rdbms/lib/sbbdpt.o `cat

/u001/app/oracle/ora904/lib/ldflags`    -lnsslb9 -lncrypt9 -lnsgr9 -lnzjs9 –

<some lines removed>

 

lcommon9 -lgeneric9  -ltrace9 -lnls9  -lcore9 -lnls9 -lcore9 -lnls9 -lxml9 -lcore9

-lunls9 -lclient9  -lvsn9 -lwtc9 -lcommon9 -lgeneric9 -lnls9  -lcore9 -lnls9

-lcore9 -lnls9 -lxml9 -lcore9 -lunls9   `cat

/u001/app/oracle/ora904/lib/sysliblist`

-Wl,-rpath,/u001/app/oracle/ora904/lib:/lib:/usr/lib -lm    `cat

/u001/app/oracle/ora904/lib/sysliblist` -ldl -lm

10.2.0.1安装的示例输出如下所示。出示的理由是为了说明在标志Oracle版本(9和10)之间的差异。换句话说,不能保证可以从一个版本提取BBED并将它用在其它版本上(当然,欢迎尝试)。

[oracle@oralinux lib]$ make -f ins_rdbms.mk $ORACLE_HOME/rdbms/lib/bbed

 

Linking BBED utility (bbed)

rm -f /opt/oracle/product/10.2.0/db_1/rdbms/lib/bbed

gcc -o /opt/oracle/product/10.2.0/db_1/rdbms/lib/bbed –

L/opt/oracle/product/10.2.0/db_1/rdbms/lib/ –

L/opt/oracle/product/10.2.0/db_1/lib/ –

L/opt/oracle/product/10.2.0/db_1/lib/stubs/ -L/usr/lib -lirc

/opt/oracle/product/10.2.0/db_1/lib/s0main.o

/opt/oracle/product/10.2.0/db_1/rdbms/lib/ssbbded.o

/opt/oracle/product/10.2.0/db_1/rdbms/lib/sbbdpt.o `cat

/opt/oracle/product/10.2.0/db_1/lib/ldflags`    -lnsslb10 -lncrypt10 -lnsgr10

<some lines removed>

-lclient10 -lnnetd10  -lvsn10 -lcommon10 -lgeneric10 -lsnls10 -lnls10  –

lcore10 -lsnls10 -lnls10 -lcore10 -lsnls10 -lnls10 -lxml10 -lcore10 -lunls10

-lsnls10 -lnls10 -lcore10 -lnls10   `cat

/opt/oracle/product/10.2.0/db_1/lib/sysliblist` -Wl,-

rpath,/opt/oracle/product/10.2.0/db_1/lib -lm    `cat

/opt/oracle/product/10.2.0/db_1/lib/sysliblist` -ldl -lm   –

L/opt/oracle/product/10.2.0/db_1/lib

为确认创建,查看是否创建BBED可执行文件。在这个例子中,make命令在rdbms/lib 目录中执行。你可以将BBED放到任何你喜欢的地方。此外,如果有需要请更改权限。

-rwxr-xr-x   1 oracle   dba   434057 Aug 25 16:26 bbed

为了证实该实用工具实际运行,调用它。本例使用10g版本,这说明发布2.0.0.0.0版本,9.0.4版本也是如此。除了著作权的变化,在相当长的一段时间内版本并未发生变化。

[oracle@oralinux lib]$ ./bbed

Password:

 

BBED: Release 2.0.0.0.0 – Limited Production on Wed Aug 27 16:17:06 2009

 

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

 

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

 

BBED>

Bbed背后的的是“大”揭秘

请注意,会提示你输入密码。几乎所有的网上搜索到的BBED参考文献都会提到,如果你动机足够强大首选使用BBED,那你就足够聪明能自己确定密码。 不管怎样。密码是blockedit。在BBED的十六进制转储文件中你会将它视为BLOCKEDIT。在/ usr/ bin中使用XXD创建BBED转储,然后在文件中查找“BBED>”。上面的几行就是BLOCKEDIT。

注意事项

首先:从客户的角度来看,BBED是个未公开的、不受支持的实用程序。如果没有引导借助Oracle Support使用这个工具,你需要独立运行。如果不知道要做什么,就不要在生产数据库中使用BBED。如果不能承受失败,就不要在任何数据库上使用BBED。提取使用此工具的数据库备份。

如果你需要恢复数据,并发现自己完全陷入困境,迄今做的很多努力也没用,这是最后的解决办法。可能会有更大更好的工具,但“此时此地”的工具就是bbed。如果需要此工具来保存/救援/恢复生产数据库,对你最有利的是先冷备份,然后提取备份的副本作为测试平台。换句话说,操作文件与实际文件分开。如果你尝试恢复数据,将其从“救援”实例转换回生产实例。

关于BBED的Oracle文档(包括在MetaLink上搜索),在公共领域内几乎检索不到。MetaLink文档62015.1有(假设它仍然存在于OSS内)一个说明,“BBED只是一个支持工具,不应与客户进行讨论。” (详见http://www.freelists.org/post/oracle-l/is-it-the-bbed    )

尽管如此,有关此工具(以及其他工具)的信息可以从Oracle软件附带的信息库中收集到。$ORACLE_HOME/rdbms/mesg 包含一个名为BBEDus.msg的文件。提取或识别文件,仔细阅读其内容以得知此工具是如何运行的。信息库内(信息库末尾)是有效的位置参数的列表,其中之一就是HELP。Oracle的Windows安装仍然包含信息库,虽然不再包含BBED.EXE。

 

有用的工具

开始运行BBED前,大概了解数据块周围的路径是很有用的,包括如何在一个表中由行获得内部块的信息。这个以及其他必要信息,通常包括绝对文件号,完整路径和数据文件的名称,块中数据文件的大小,数据块地址,块编号,块大小和块类型等信息。

你需要一个报告工具输出有关块的信息。不止一种方法可以得到这个信息,但最简单的是基于使用内置的名为DBMS_ROWID所提供的PL / SQL。至少在Oracle8i中的文件包(有十大功能和一个程序)已经可用,但使用这个文件包对你而言是全新的(你多久会挖掘一次数据块的内部信息?)。几个功能信息借助OUT参数,在一个过程中结合。围绕DBMS_ROWID.ROWID_INFO创建自己的包装过程,使之可重复使用。

我们看一下这个过程包含什么 (Oracle® Database PL/SQL Packages and Types Reference 10g Release 2 (10.2)).

ROWID_INFO 步骤

该过程返回到有关ROWID的信息,包括其类型(限制或扩展),以及ROWID的组件。这是一个过程,不能在SQL语句中使用。

句法

DBMS_ROWID.ROWID_INFO (

   rowid_in         IN   ROWID,

   ts_type_in       IN   VARCHAR2 DEFAULT ‘SMALLFILE’,

   rowid_type       OUT  NUMBER,

   object_number    OUT  NUMBER,

   relative_fno     OUT  NUMBER,

   block_number     OUT  NUMBER,

   row_number       OUT  NUMBER);

样本“get_rowinfo”包装过程如下所示。

create or replace procedure get_rowinfo(rid in rowid) as

  sm      varchar2(9) := ‘SMALLFILE’;

  rid_t   number;

  obj_n   number;

  file_n  number;

  block_n number;

  row_n   number;

begin

  DBMS_ROWID.ROWID_INFO(rid, rid_t, obj_n, file_n, block_n, row_n, sm);

  DBMS_OUTPUT.PUT_LINE(‘Type:            ‘ || to_char(rid_t));

  DBMS_OUTPUT.PUT_LINE(‘Data obj number: ‘ || to_char(obj_n));

  DBMS_OUTPUT.PUT_LINE(‘Relative fno:    ‘ || to_char(file_n));

  DBMS_OUTPUT.PUT_LINE(‘Block number:    ‘ || to_char(block_n));

  DBMS_OUTPUT.PUT_LINE(‘Row number:      ‘ || to_char(row_n));

end;

/

注意占位符变量是如何用于OUT参数,且可以直接引用。代码中的参数列表还显示了过去在列表中传递的文件类型(SMALLFILE)。文档将此显示为第二个参数,这是不对的。对文件包发出的描述命令显示也是如此。

结束语

安装BBED相当简单,并且一旦超密密码已知,就能够使用该工具打开多种可能性。只能够看到数据如何存储在一个文件中,其本身是有价值的,正如Oracle如何以目前的状态来标签或标记数据块。在以后的文章中,我们将使用裸骨数据库并查看数据文件的内容。

Comment

*

沪ICP备14014813号-2

沪公网安备 31010802001379号