如何格式化不属于任何段的损坏块

[[196780]]

一、问题症状:

1. Rman 备份失败,显示 ORA-19566 错误,且被报告的坏块不属于任何对象

2. Dbverify 显示存在坏块

3. 坏块不属于任何对象

二、原因分析:

在重新使用和重新格式化坏块之前,RMAN 和 DBV 仍会一直报告坏块。

三、解决方案:

解决此类问题的一个可能的方法如下。请注意,它不能保证问题解决,但它已知解决了几种案例的问题。如果在某个数据文件中报告有很多块损坏,请在第六步提示输入 blocknumber 中输入已经报告的***的坏块号码。

当一个对象被重新创建,已经分配给它(甚至是损坏的块)的块将变成空闲空间(free space)。他们在那里等待重新分配到一个需要额外空间的对象。一旦它们被重新分配到用于一个对象上新的extent,只有当任何DML操作使用到这些块(即使损坏的块,处在空闲空间,现在需要被分配),他们将在DML操作更改、使用这些块之前,被重新格式化掉。

需要注意的是extent的简单的分配不格式化块。第7步分配的extent和第8步执行DML操作,使用在第七步中分配的块,这样的坏块才被重用和格式化。

在本文档中,我们尝试手动重新格式化坏块。

第 1 步 – 确定损坏的数据文件

损坏可以被报告在应用层,如DBV和RMAN,或alert.log。

例如,可以在您的RMAN备份过程中获得以下信息:

RMAN-03009: failure of backup command on nm4501 channel at 04/29/2005 09:44:41

ORA-19566: exceeded limit of 0 corrupt blocks for file E:\xxxx\test.ORA.

坏块位于文件 E:\xxxx\test.ORA 中。

第 2 步 – 在受影响的数据文件上运行 DBV/Rman 验证并检查坏块

在报告坏块的数据文件上运行 dbverify。

  1. # dbv userid={system/password} file={full path filename} logfile={output filename} 

第 3 步 – 检查块是否是某个对象的一部分 – 适用于损坏的块号小的情况

查询 dba_extents,确认坏块是否属于任何对象。

  1. SQL> select segment_name, segment_type, owner 
  2.        from dba_extents 
  3.       where file_id = <Absolute file number> 
  4.         and <corrupted block number> between block_id 
  5.             and block_id + blocks -1;  

如果块不属于任何对象,查询dba_free_space 确认坏块是否属于数据文件的可用空间。

  1. SQL> Select * from dba_free_space where file_id= <Absolute file number> 
  2.      and <corrupted block number> between block_id and block_id + blocks -1;  

第 4 步 – 查找受影响的块并验证其是否属于任何段的一种比较好的方法是使用 RMAN,这种方法既好用又便捷。

如果在第 2 步中已经运行了 rman 验证,请直接转到下面给出的 sqlplus 脚本,以确认对象。

  1. $ rman target / nocatalog 
  2. or 
  3. $ rman target sys/ nocatalog 
  4.  
  5.  
  6. run { 
  7. allocate channel d1 type disk; 
  8. allocate channel d2 type disk; 
  9. ---------------------------------------------------------------------- 
  10. --  multiple channels may be allocated for parallelizing purposes 
  11. --  depends: RMAN - Min ( MAXOPENFILES , FILESPERSET )  
  12. --  Defaults: MAXOPENFILES =8, FILESPERSET =64  
  13. ---------------------------------------------------------------------- 
  14. allocate channel dn type disk; 
  15. backup check logical validate database; 

注意:如果RDBMS是小于11g并且处于非归档模式下,则数据库必须处于 mounted 模式

*** 在进行进一步操作之前,*必须*运行并完成 RMAN 命令“backup check logical validate database”。

*** 此命令完成(基于文件)后将会填充“v$database_block_corruption”视图。

*** 如果未完成,在接下来的步骤中您就有可能得到无效/不完整的信息。

第 5 步 – 以非 SYS 或 SYSTEM(用户)的用户身份创建一个虚拟表

  1. SQL> connect scott/password 

在包含出现坏块的数据文件的表空间中创建虚拟表,并使用 nologging 选项,以防止生成 redo记录:

  1. SQL> create table s ( 
  2.        n number, 
  3.        c varchar2(4000) 
  4.      ) nologging tablespace <tablespace name having the corrupt block> ;   

不同的存储参数可以被用来适应特定的环境。

我们使用 PCTFREE 99以加快该块的格式化

确认表是被创建在正确的表空间中,通过查询 user_segments:

  1. QL> select segment_name,tablespace_name from user_segments 
  2.       where segment_name='S' ;  

请注意,在11gR2中,由于延迟段创建概念,从上面提到的 user_segments 查询可能不会报告。在这种情况下,查询 USER_TABLES

  1. SQL> select segment_name,tablespace_name from user_tables where segment_name='S' ; 

第 6 步 – 在虚拟表上创建触发器,一旦重新使用坏块,该触发器便会引发异常

以 sysdba 身份连接,并创建以下触发器:

请注意,在出现文件号提示时,输入相关文件号(v$datafile 中的 rfile# 值)

  1. CREATE OR REPLACE TRIGGER corrupt_trigger  
  2.   AFTER INSERT ON scott.s  
  3.   REFERENCING OLD AS p_old NEW AS new_p  
  4.   FOR EACH ROW  
  5. DECLARE  
  6.   corrupt EXCEPTION;  
  7. BEGIN  
  8.   IF (dbms_rowid.rowid_block_number(:new_p.rowid)=&blocknumber) 
  9.  and (dbms_rowid.rowid_relative_fno(:new_p.rowid)=&filenumber) THEN  
  10.      RAISE corrupt;  
  11.   END IF;  
  12. EXCEPTION  
  13.   WHEN corrupt THEN  
  14.      RAISE_APPLICATION_ERROR(-20000, 'Corrupt block has been formatted');  
  15. END;  
  16.  

出现块编号提示时,输入坏块的块编号。

出现文件号提示时,输入损坏的数据文件的相关文件号(v$datafile 中的 rfile# 值)。

第 7 步 – 为受影响的数据文件中的表分配空间。

请注意:

1)如果这是一个ASSM表空间,你可能需要重复此步骤数次。也就是说,创建多个表和分配多个 extent。

并周期性地查看 dba_extents,以确保空闲空间现在分配给一个虚拟表。

这是因为ASSM将自动确定下一个 extent 的大小

2)建议确保数据文件 AUTOEXTEND 置为 OFF,以防止其增长。

首先通过查询 dba_free_space 查找 extent 大小

  1. SQL> Select BYTES from dba_free_space where file_id=<file noand <corrupt block nobetween block_id and block_id + blocks -1; 
  2.  
  3. BYTES 
  4. ---------------- ---------- ---------- ---------- ---------- ------------ 
  5.  65536  

在本例中,它的大小是 64K。因此,按照以下方法分配 extent:

  1. SQL> alter table scott.s 
  2.  
  3. allocate extent (DATAFILE 'E:\xxxx\test.ORA' SIZE 64K);  

如果在这个数据文件中有多个64K的空闲 extent,则可能需要使用这个循环:

  1. BEGIN 
  2. for i in 1..1000000 loop 
  3. EXECUTE IMMEDIATE 'alter table scott.s allocate extent (DATAFILE '||'''E:\xxxx\test.ORA''' ||'SIZE 64K) '
  4. end loop; 
  5. end ; 
  6.  

继续分配空间直到坏块成为 scott.s 的一部分 — 使用以下查询进行检查:

  1. SQL> select segment_name, segment_type, owner 
  2.        from dba_extents  
  3.       where file_id = <Absolute file number> 
  4.         and <corrupt block number> between block_id  
  5.             and block_id + blocks -1 ;  

第 8 步 – 向虚拟表中插入数据以格式化块

示例代码(取决于表空间的大小,循环的次数可能发生变化):

  1. BEGIN  
  2. FOR i IN 1..1000000000 LOOP  
  3. INSERT /*+ APPEND */ INTO scott.s select i, lpad('REFORMAT',3092, 'R'from dual;  
  4. commit ;  
  5. END LOOP;  
  6. END 

或者

  1. BEGIN 
  2.   FOR i IN 1..1000000000 LOOP 
  3.     INSERT INTO scott.s VALUES(i,'x'); 
  4.   END LOOP; 
  5. END
  6.  

或使用以下包含 2 个循环的代码:

  1. Begin 
  2.   FOR i IN 1..1000000000 loop 
  3.     for j IN 1..1000 loop 
  4.       Insert into scott.s VALUES(i,'x'); 
  5.     end loop; 
  6.     commit
  7.   END LOOP; 
  8. END;   

每向表中插入一行就会触发触发器,且一旦向坏块中插入***行数据,就会产成 ORA-20000 异常。

第 9 步 – 通过运行 DBV 和 Rman 备份确定数据文件中的坏块情况

运行 dbverify 或 RMAN 在损坏的数据文件(或整个数据库)上再次验证。它不会显示块损坏。

确保你做两次手动日志切换或检查点,使得在内存中的信息写入到磁盘。

RMAN 备份不会报告此块上的任何错误。

运行真实的备份操作之前,你可以在数据文件上重新运行 RMAN validate 命令,并检查 v$database_block_corruption 不再显示块被标记为损坏。

对于数据库版本 <=10gR2

  1. Rman> Backup validate check logical datafile <fileno>,<fileno> ; 

对于数据库版本>=11gR1

  1. Rman> Backup validate check logical datafile <fileno> ; 

  1. Rman> validate datafile <fileno> block <blockno reported corrupt>, <blockno reported corrupt> ; 

一旦完成

  1. SQL> SELECT * FROM V $ DATABASE_BLOCK_CORRUPTION; 

第 10 步 – 删除第 4 步中创建的虚拟表

  1. SQL> DROP TABLE scott.s ; 

如果版本为 10gr1 及以上,同时使用purge选项以清空回收站

第 11 步 – 执行手动日志切换和检查点

执行两次日志切换和检查点,以便将在内存中格式化的块写入到磁盘并使 dbverify 不再报告错误

  1. SQL>Alter system switch logfile ; --> Do this couple of time 
  2.  
  3. SQL>Alter system checkpoint ;  

第 12 步 – 删除第 6 步中创建的触发器

  1. SQL> DROP triggercorrupt_trigger ;  

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/307045.html<

(0)
运维的头像运维
上一篇2025-05-26 22:50
下一篇 2025-05-26 22:52

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注