[20150527]bbed解决数据文件大小问题.txt-阿里云开发者社区

开发者社区> lfreeali> 正文

[20150527]bbed解决数据文件大小问题.txt

简介: [20150527]bbed解决数据文件大小问题.txt --模拟一个数据文件大小不一致的问题. 1.建立测试环境: SCOTT@test> @ &r/ver1 PORT_STRING                    VERSION       ...
+关注继续查看

[20150527]bbed解决数据文件大小问题.txt

--模拟一个数据文件大小不一致的问题.

1.建立测试环境:

SCOTT@test> @ &r/ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- ----------------------------------------------------------------
x86_64/Linux 2.4.xx            10.2.0.4.0     Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bi

SCOTT@test> select file#,name,bytes from v$datafile ;
FILE# NAME                                     BYTES
----- --------------------------------- ------------
    1 /mnt/ramdisk/test/system01.dbf       534773760
    2 /mnt/ramdisk/test/undotbs01.dbf      367001600
    3 /mnt/ramdisk/test/sysaux01.dbf       387973120
    4 /mnt/ramdisk/test/users01.dbf        104857600
    5 /mnt/ramdisk/test/example01.dbf      104857600
    6 /mnt/ramdisk/test/mssm01.dbf          16777216
6 rows selected.

$  ls -l /mnt/ramdisk/test/mssm01.dbf
-rw-r----- 1 oracle oinstall 16785408 2015-05-27 10:52:05 /mnt/ramdisk/test/mssm01.dbf

16785408-16777216=8192
--可以发现视图v$datafile显示的与os看的有8192字节差距,实际上前面1块OS块,记录一个OS信息.

--16777216=16M,不好观察数据文件的大小的定义在什么位置.
SCOTT@test> select (16777216-2*64*1024)/1024 from dual ;
(16777216-2*64*1024)/1024
-------------------------
                    16256

SCOTT@test> ALTER DATABASE DATAFILE '/mnt/ramdisk/test/mssm01.dbf' RESIZE 16256K;
Database altered.

16256/8=2032
2032 = 0x7f0

--通过bbed观察:
BBED> set dba 6,1
        DBA             0x01800001 (25165825 6,1)

BBED> p kcvfhhdr
struct kcvfhhdr, 76 bytes                   @20
   ub4 kccfhswv                             @20       0x00000000
   ub4 kccfhcvn                             @24       0x0a200300
   ub4 kccfhdbi                             @28       0x80f1c038
   text kccfhdbn[0]                         @32      T
   text kccfhdbn[1]                         @33      E
   text kccfhdbn[2]                         @34      S
   text kccfhdbn[3]                         @35      T
   text kccfhdbn[4]                         @36
   text kccfhdbn[5]                         @37
   text kccfhdbn[6]                         @38
   text kccfhdbn[7]                         @39
   ub4 kccfhcsq                             @40       0x33c3d8a7
   ub4 kccfhfsz                             @44       0x000007f0

--应该是kcvfhhdr.kccfhfsz字段.

2.安全第1,关闭数据库,做一个冷备份:
--步骤忽略.

3.修改偏移量44,45:
--FF,7F ,注意要反过来. 相当于修改为07FF=2047.

BBED> sum apply
Warning: contents of previous BIFILE will be lost. Proceed? (Y/N) y
Check value for File 6, Block 1:
current = 0x9632, required = 0x9632

4.启动数据库观察:
SYS@test> startup
ORACLE instance started.
Total System Global Area    473956352 bytes
Fixed Size                    2084776 bytes
Variable Size               260046936 bytes
Database Buffers            201326592 bytes
Redo Buffers                 10498048 bytes
Database mounted.
ORA-01122: database file 6 failed verification check
ORA-01110: data file 6: '/mnt/ramdisk/test/mssm01.dbf'
ORA-01200: actual file size of 2032 is smaller than correct size of 2047 blocks

5.修改很简单,修改原来的44,45字节为正确的 2032 = 0x7f0.

BBED> set dba 6,1
        DBA             0x01800001 (25165825 6,1)

BBED> p kcvfhhdr.kccfhfsz
ub4 kccfhfsz                                @44       0x000007ff

BBED> modify /x f007

BBED> p kcvfhhdr.kccfhfsz
ub4 kccfhfsz                                @44       0x000007f0


BBED> sum apply
Check value for File 6, Block 1:
current = 0x963d, required = 0x963d

SYS@test> startup
ORACLE instance started.
Total System Global Area    473956352 bytes
Fixed Size                    2084776 bytes
Variable Size               260046936 bytes
Database Buffers            201326592 bytes
Redo Buffers                 10498048 bytes
Database mounted.
Database opened.

--OK现在正常了,这种错误可能出现磁盘满了,而空间增加的情况,不过真实的模拟存在一些难度,至少我没有模拟出来.修改方法应该就像上面的介绍.

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
[20170111]设置无需口令登录数据库.txt
[20170111]设置无需口令登录数据库.txt --以前链接提到的http://blog.itpub.net/267265/viewspace-2124815/,必须考虑一种方式登录避免口令的暴露。
898 0
VS2010无法保存项目文件(.csprj)的问题解决方法
VS2010无法保存项目文件(.csprj)的问题解决方法   【出错提示】保存项目文件“XXX”时出错。类没有注册。正在查找具有CLSID的对象:{D9B3211D-E57F-4426-AAEF-30A806ADD397}。
968 0
[20121115]关于oracle数据文件的第1块.txt
[20121115]关于oracle数据文件的第1块.txt每个数据文件的第一个块(block 0)是OS block header,在数据库中查询不到信息,记录的是OS信息,以及文件大小的等信息.今天做一些简单的研究。
789 0
sql server 2005日志文件过大问题解决后分析--针对发布订阅产生的日志问题
机房在四月份改造中对数据库的软硬件进行了升级,具体情况是:原先旧有的数据库是采用主备两台1u的单机,在windows 2000的系统下分别安装好sql server 2000后,在主数据库上做一天一次的完整备份和每隔两小时的差异备份,在完整备份的同时进行发布;备数据库则对主数据库的完整备份进行订阅。
920 0
"无法删除数据库,因为该数据库当前正在使用"问题解决
原文:"无法删除数据库,因为该数据库当前正在使用"问题解决 异常处理汇总-数据库系列  http://www.cnblogs.com/dunitian/p/4522990.html  以前刚学数据库的时候比较苦恼这个问题,今天删除的时候又看见了,正好一起记录一下: 图形化方法: 命令行方法...
1261 0
[20121127]rman备份数据文件大小与truncate.txt
[20121127]rman备份数据文件大小与truncate.txt记得以前看rman的书,rman仅仅备份已经格式话的块,如果这样一个表被truncate后,即使空间回收了。
836 0
[20121227]v$datafile访问是从数据文件获取信息吗.txt
[20121227]v$datafile访问是从数据文件获取信息吗.txt记得以前开始学习oracle的时候,被问及访问v$datafile从哪里获取信息,当时想都没想,从数据文件.
678 0
[20130104]快速移动数据文件.txt
[20130104]快速移动数据文件.txt如果要快速移动数据文件,对业务的影响最小,可以使用rman的backup as copy功能,先拷贝文件到需要移动的目录,然后再追加增量变化,再利用增量备份来恢复copy文件,再切换数据文件。
642 0
+关注
lfreeali
熟悉oracle数据库性能优化,rman备份,数据库恢复技术.
2122
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载