临时表空间的管理与受损恢复

2023-10-10 21:58

本文主要是介绍临时表空间的管理与受损恢复,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      Oracle 临时表空间是Oracle数据库的重要组成部分,尽管该部分并没有cont体系结构上得以展现,但其重要地位也是不容忽视的。尤其是
对于大型的频繁操作,如创建索引,排序等等都需要在临时表空间完成来减少内存的开销。当然对于查询性能要求较高的应尽可能的避免在磁盘
上完成这些操作。本文主要描述的是临时表空间的管理与受损恢复。

一、临时表空间的特性与注意事项
  1.特性
       用户存储临时数据的表空间
       临时数据通常只在一个数据库会话期间内存在的数据,分为两种形式,排序数据和全局临时表
       临时数据不会被写入存储永久对象的普通表空间内,而是存储在临时表空间的临时段中
       临时表空间临时性导致不需要备份该类型的表空间,RMAN也不支持对临时表空间的备份
       对于临时数据的处理,不会生成重做,也不会生成撤销数据
       临时表空间的数据文件不能置为只读、不能重命名
       监时表空间的数据文件的日志方式总是NOLOGGING
       使用临时表空间的主要操作
        CREATE INDEX,ALTER INDEX ...REBUILD,ORDER BY,GROUP BY,DISTINCT,UNION,INTERSECT,MINUS,SORT-MERGER,JOIN,ANALYZE
      
  2.临时表空间使用的注意事项
       a. 每个用户都有一个缺省的临时表空间,对于临时表空间使用较高的系统,建议将临时表空间数据文件分布到不同的磁盘
       b. 对于大型操作频繁,(大型查询,大型分类查询,大型统计分析等),应指定单独的临时表空间,以方便管理
       c. 分配用户单独临时表空间,一般是针对大型产品数据库,OLTP数据库,数据库仓库
       d. 对于小型产品不需要单独制定临时表空间,使用默认临时表空间
       e. 对于临时表空间建议关闭自动扩展功能,避免过度扩展所致的空间压力 
  关于临时表空间的创建与管理请参考:Oracle 表空间与数据文件
二、临时表空间的管理
  1. 查看缺省的临时表空间

SQL> select property_name,property_value from database_properties       2  where property_name like 'DEFAULT%';                               PROPERTY_NAME                  PROPERTY_VALUE                           
------------------------------ --------------------------------         
DEFAULT_TEMP_TABLESPACE        TEMP                                     
DEFAULT_PERMANENT_TABLESPACE   USERS                                    
DEFAULT_TBS_TYPE               SMALLFILE                                

  2.查看临时表空间的大小及位置    

SQL> select s.name tbsname,t.name,(t.bytes/1024/1024) bytes,status                      2  from v$tablespace s,v$tempfile t                                                   3  where s.ts# = t.ts#;                                                               TBSNAME    NAME                                               BYTES   STATUS            
---------- --------------------------------------------- ----------   -------           
TEMP       /u01/app/oracle/oradata/orcl/temp01.dbf               30   ONLINE            SQL> select tablespace_name,file_name,bytes/1024/1024 Size_MB from dba_temp_files;      TABLESPACE FILE_NAME                                        SIZE_MB                     
---------- --------------------------------------------- ----------                     
TEMP       /u01/app/oracle/oradata/orcl/temp01.dbf               30                     SQL> select tablespace_name,logging,allocation_type                                     2  from dba_tablespaces where tablespace_name='TEMP';                                 TABLESPACE LOGGING   ALLOCATIO                                                          
---------- --------- ---------                                                          
TEMP       NOLOGGING UNIFORM                                                            

  3. 临时表文件大小和已使用空间    

SELECT t1."Tablespace" "Tablespace",                                                        t1."Total (G)" "Total (G)",                                                          nvl(t2."Used (G)", 0) "Used(G)",                                                     t1."Total (G)" - nvl(t2."Used (G)", 0) "Free (G)"                                    
FROM   (SELECT tablespace_name "Tablespace",                                                to_char((SUM(bytes / 1024 / 1024 / 1024)), '99,999,990.900') "Total (G)"     FROM   dba_temp_files                                                               GROUP  BY tablespace_name                                                           UNION                                                                               SELECT tablespace_name "Tablespace",                                                to_char((SUM(bytes / 1024 / 1024 / 1024)), '99,999,990.900') "Total (G)"     FROM   dba_data_files                                                               WHERE  tablespace_name LIKE 'TEMP%'                                                 GROUP  BY tablespace_name) t1,                                                      (SELECT tablespace, round(SUM(blocks) * 8 / 1024 /1024) "Used (G)"                         FROM   v$sort_usage                                                                 GROUP  BY tablespace) t2                                                            
WHERE  t1."Tablespace" = t2.tablespace(+);                                                  Tablespace                     Total (G)          Used(G)   Free (G)                        
------------------------------ --------------- ---------- ----------                        
GOEX_TEMP                               31.999          1     30.999                        
FIX_TEMP                                 0.098          0       .098                        
TEMP                                     0.195          0       .195                        

  4. 查看当前临时表使用空间大小与正在占用临时表空间的sql语句  

-->使用临时段的SQL语句                                                        SELECT sess.SID, segtype, blocks * 8 / 1000 "MB", sql_text                  FROM   v$sort_usage sort, v$session sess, v$sql SQL                         WHERE  sort.SESSION_ADDR = sess.SADDR                                       AND SQL.ADDRESS = sess.SQL_ADDRESS                                   ORDER  BY blocks DESC;                                                      -->下面的查询也可以查询谁正在使用临时段                                       col username format a15                                                     col machine format a15                                                      col program format a30                                                      col tablespace format a15                                                   set linesize 160                                                            SELECT s.username                                                           ,s.sid                                                                ,s.serial#                                                            ,s.sql_address                                                        ,s.machine                                                            ,s.program                                                            ,su.tablespace                                                        ,su.segtype                                                           ,su.contents                                                          FROM   v$session s, v$sort_usage su                                         WHERE  s.saddr = su.session_addr;                                           SELECT 'the ' || NAME || ' temp tablespaces ' || tablespace_name ||           ' idle ' ||                                                            round(100 - (s.tot_used_blocks / s.total_blocks) * 100, 3) ||          '% at ' || to_char(SYSDATE, 'yyyymmddhh24miss')                        
FROM   (SELECT d.tablespace_name tablespace_name,                             nvl(SUM(used_blocks), 0) tot_used_blocks,                      SUM(blocks) total_blocks                                       FROM   v$sort_segment v, dba_temp_files d                             WHERE  d.tablespace_name = v.tablespace_name(+)                       GROUP  BY d.tablespace_name) s,                                       v$database;                                                            

   3. 修改默认的临时表空间
           alter database default temporary tablespace tablespace_name;
   4. 对于过度使用临时表空间,在允许的情况下,可以杀掉其session
           alter system kill session 'sid,serial#';  
   
三、临时表空间故障
  前面已提到,临时表空间不需要备份,如果对临时表空间备份将收到错误提示  

SQL> alter tablespace temp begin backup;                        
alter tablespace temp begin backup                              
*                                                               
ERROR at line 1:                                                
ORA-03217: invalid option for alter of TEMPORARY TABLESPACE     SQL> alter temporary tablespace temp begin backup;              
alter temporary tablespace temp begin backup                    *                                                         
ERROR at line 1:                                                
ORA-00940: invalid ALTER command                                

  临时表空间出错的错误提示(位于告警日志中alert_orcl.log)
   Errors in file /u01/app/oracle/admin/orcl/bdump/orcl_dbw0_2230.trc:
   ORA-01186:file 3 failed verification tests
   ORA-01157:cannot identify/lock data file 3 - see DBWR trace file
   ORA-01110:data file 3:'/u01/app/oracle/oradata/orcl/temp01.dbf'
 
四、还原受损的临时表空间
  1. 在session 1中删除临时表空间的数据文件

SQL> show user;                                    
USER is "SYS"                                      
SQL> ho rm /u01/app/oracle/oradata/orcl/temp01.dbf SQL> alter system checkpoint;  -->执行检查点进程   System altered.                                    

  2. 在session 2中执行排序查询,提示临时数据文件错误   

SQL> show user;                                                                   
USER is "SCOTT"                                                                   
SQL> set autotrace traceonly;                                                     
SQL> select owner,object_name from big_table order by id,owner,object_name;       
select owner,object_name from big_table order by id,owner,object_name             *                                                   
ERROR at line 1:                                                                  
ORA-01565: error in identifying file '/u01/app/oracle/oradata/orcl/temp01.dbf'    
ORA-27037: unable to obtain file status                                           
Linux Error: 2: No such file or directory                                         
Additional information: 3                                                         

  3. 在session 1中为临时表空间增加数据文件  

SQL> alter tablespace temp add tempfile '/u01/app/oracle/oradata/orcl/temp02.dbf'      2  size 30m autoextend on next 1m maxsize 2g;                                        Tablespace altered.                                                                    

  4. 在session 2中继续执行排序操作,此次执行成功  

SQL> select owner,object_name from big_table order by id,owner,object_name;        1000000 rows selected.                                                             

  5. 查询临时数据文件状态及文件存在性 

SQL> set linesize 160                            --> session 1中查看临时数据文件状态,大小为0,但仍然为online状态   
SQL> select s.name tbsname,t.name,(t.bytes/1024/1024) bytes,t.status                                               2  from v$tablespace s,v$tempfile t                                                                              3  where s.ts# = t.ts#;                                                                                          TBSNAME              NAME                                               BYTES STATUS                               
-------------------- --------------------------------------------- ---------- -------                              
TEMP                 /u01/app/oracle/oradata/orcl/temp01.dbf                0 ONLINE                               
TEMP                 /u01/app/oracle/oradata/orcl/temp02.dbf               30 ONLINE                               SQL> ho ls /u01/app/oracle/oradata/orcl/temp01.dbf                                                                 
ls: /u01/app/oracle/oradata/orcl/temp01.dbf: No such file or directory                                             

  6. 清除控制文件内记录的不存在的临时文件信息 

SQL> alter tablespace temp drop tempfile '/u01/app/oracle/oradata/orcl/temp01.dbf';   Tablespace altered.                                                                   

  7. 基于表空间级别的恢复操作(下面给出主要步骤,不在演示)
       a. 创建一个新的临时表空间
       b. 使用alter database 将用户切换到新的临时表空间,即设置新的默认的临时表空间
       c. 删除受损的临时表空间
  

这篇关于临时表空间的管理与受损恢复的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/183351

相关文章

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

NGINX轻松管理10万长连接 --- 基于2GB内存的CentOS 6.5 x86-64

转自:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=190176&id=4234854 一 前言 当管理大量连接时,特别是只有少量活跃连接,NGINX有比较好的CPU和RAM利用率,如今是多终端保持在线的时代,更能让NGINX发挥这个优点。本文做一个简单测试,NGINX在一个普通PC虚拟机上维护100k的HTTP

PMBOK® 第六版 规划进度管理

目录 读后感—PMBOK第六版 目录 规划进度管理主要关注为整个项目期间的进度管理提供指南和方向。以下是两个案例,展示了进度管理中的复杂性和潜在的冲突: 案例一:近期,一个长期合作的客户因政策要求,急需我们为多家医院升级一个小功能。在这个过程中出现了三个主要问题: 在双方确认接口协议后,客户私自修改接口并未通知我们,直到催进度时才发现这个问题关于UI设计的部分,后台开发人员未将其传递给

如何恢复回收站中已删除/清空的文件

回收站清空后如何恢复已删除的文件?是否可以恢复永久删除的文件?或者最糟糕的是,如果文件直接被删除怎么办?本文将向您展示清空回收站后恢复已删除数据的最佳方法。 回收站清空后如何恢复已删除的文件? “回收站清空后我还能恢复已删除的文件吗?” 答案是肯定的,但是在这种情况下您将需要一个  回收站恢复工具 来从回收站中检索文件: 错误/永久删除回收站或任何数字存储设备中的文件 直接删除的文件/