管理undo

管理undo

1 undo作用

管理undo

 

 

undo数据是:

  • 原始的、修改之前的数据副本
  • 是针对更改数据的每个事务处理所捕获的·至少保留到事务处理结束
  • 用于支持:
    •   回退操作
    •   读取一致性查询
    •   闪回查询、闪回事务处理和闪回表一从失败的事务处理中进行恢复

 

UNDO提供以下四种情况所需要的信息

  • 回滚事务:rollback
  • 读一致性:正在做DML操作的数据块,事务结束前,其他用户读undo里面的数据前镜像
  • 实例的恢复:instance recover(undo -->rollback)
  • 闪回技术:flashback query、flashback table等

1.1 事务的属性

 

ACID

原子性:一个事务的所有部分必须都完成, 或者都不完成

一致性:查询的结果必须与数据库在查询开始时的状态一致

隔离性:除了作出变更的会话,其他会话都无法看到未提交的数据

持久性:事务一旦完成,不可丢失

管理undo

 

 

 

2 Undo和Redo对比

管理undo

 

 

2.1 update语句执行逻辑流程redo undo信息

管理undo

 

 

 

3 Undo的参数

3.1 三个基本参数

show parameter undo

管理undo

 

 

  • undo_management
    •   manaual     仅在维护时使用
    •   auto            使用undo tablespace管理undo
  • undo_retention             指定保留期单位秒,希望在这个期间commit的undo数据不要覆盖
  • undo_tablespace          当前使用的Undo表空间

3.2 建立一个undo表空间

可以建立多个undo表空间,但只有一个是使用中的undo

使用中的undo tablespace不能offline和drop

查看当前undo表空间

show parameter undo_tablespace

管理undo

 

 

查看表空间对应数据文件

col file_name for a60
select tablespace_name,file_name from dba_data_files;

管理undo

 

 

select tablespace_name,contents from dba_tablespaces;

管理undo

 

 

建立一个新的undo表空间

create undo tablespace UNDOTBS2 datafile '/u01/app/oracle/oradata/ORCL/undotbs02.dbf' size 50M autoextend on;

管理undo

 

 

查看当前正在使用的undo段(回滚段)

select * from v$rollname;

管理undo

 

 

3.3 切换undo

und 表空间很难缩小,但是可以替换

alter system set undo_tablespace=undotbs2;        --动态参数,修改立即生效

管理undo

 

 

show parameter undo_tablespace;
select * from v$rollname;

管理undo

 

 

查看undo段中区的状态:select segment_name,tablespace_name,status from dba_undo_extents order by status;

彻底删除undotbs1表空间

drop tablespace undotbs1 including contents and datafiles;

管理undo

 

 

删除未激活undo时要慎重操作,之前的undotbs1可能仍然在使用

即使没有事务用之前的undotbs1,可能有查询语句用到unexpired状态的undo数据

 

4 Undo空间重用机制3种状态

管理undo

 

 

管理undo

 

 

管理undo

 

 

undo段中区的状态:

① active:表示 transaction(事务) 还没有 commit,不可覆盖

② unexpired:由已经commit数据转换而来的状态,在保留期内,尽量不覆盖(非强制)

③ expired:由unexpired转换而来,其中的数据是超过undo保留期的,随时可以再分配(覆盖)

undo的状态转换体现了undo空间的循环使用
  分配---》 冻结--->回收---》 再分配

 

5 关于AUM(Auto Undo Management)

5.1 Auto Undo Management

Oracle10gR2以后引入了一个新的自动调整undo retention的特性,目的是尽量避免两个Undo错误:

  • ora-30036 错误---空间不足
  • ora-01555 错误---快照太旧

11g缺省设置为AUM(Auto Undo Management)

AUM下current undo retention是自动调整的

select begin_time,tuned_undoretention from v$undostat;

管理undo

 

 

5.2 AUM的两种工作方式

① autoextend off下,忽略undo_retention 参数,TUNED_UNDORETENTION参照undo表空间大小和undo统计信息

缺点:空间给定不合理时,产生UNDO告警,不能完全避免ora-30036,ora-01555,若UNDO增加尺寸,又可能造成TUNED_UNDORETENTION增加

② autoextend on下,参考undo_retention作为下限值,TUNED_UNDORETENTION期内,以扩展空间代替覆盖unexpired,基本避免了ora-30036,ora-01555

select file_name,tablespace_name,AUTOEXTENSIBLE from dba_data_files;

管理undo

 

 

5.3 Undo表空间的retention guarantee属性

管理undo

 

 

通常情况下,unexpired数据并不绝对保证在retention期内不会覆盖,必要时可考虑设置在保留期强制不覆盖的guarantee属性,同时应该使undo autoextend on

select tablespace_name,status,contents,retention from dba_tablespaces;

管理undo

 

 

缺省配置下undo retention是noguarantee   (guarantee属性慎重使用)

guarantee属性可以修改

alter tablespace undotbs2 retention guarantee;

管理undo

 

保证unexpired状态undo数据在retention期间不被覆盖

select tablespace_name,status,contents,retention from dba_tablespaces;

管理undo

 

取消undo表空间guarantee属性

alter tablespace undotbs2 retention noguarantee;

管理undo

 

 

6 undo信息的查询

dba_undo_extents    查看undo段中不同状态区的空间占用

管理undo

 

 

7 12C Temporary Undo

管理undo

 

  临时表被广泛的用于存放中间结果。因为写这些表要快,没有redo。然而临时表中的操作对应的UNDO还是要记录redo的,在临时表对象的生命周期内,对读一致性和事务回滚都是有用的。对于实例来说,事务恢复会丢弃临时对象的undo。从12C开始,可以将临时表的事务生成的Undo信息直接存放在临时表空间独立存在,避免将undo存放到redo。这个模式称为临时Undo。

注:临时Undo段是会话私有的,它存放会话对应的临时表生成的Undo信息

管理undo

 

使用临时undo提供了如下功能:

  临时Undo减少了Undo表空间的数据,更少的Undo记录可以更好的满足保留时长要求。性能也被改善,因为更少的数据被写入到redo log,例如日志挖掘对更少的redo数据解析。在ADG的物理备库对临时表的DML操作使用临时undo,然而DDL操作必须在主库中创建临时表。

管理undo

 

  可以在会话级别启用临时undo,也可以在整个数据库级别启用。当通过ALTER SESSION命令启用会话级别时,会话创建临时undo不会影响到其它会话。当通过ALTER SYSTEM命令启用数据库级别时,所有已存在的会话和新会话也会创建临时undo。

  如果对会话开启了临时undo之后,会话正在使用临时对象,当前会话是不能禁用临时undo的。同样,如果临时undo在会话中禁用并且会话使用临时对象,当前会话不能启用临时Undo。注:临时undo特性在数据库中的兼容性至少为12.1.0.0时生效。在ADG的物理备库中临时undo默认是开启的。因为这个特性TEMP_UNDO_ENABLED参数不会影响ADG中的物理备库。

管理undo

 

VSTEMPUNDOSTAT展示了数据库实例中和临时undo日志相关的多种统计信息。显示了和系统如何工作运行的柱状图统计信息。每隔10分钟视图会收集统计信息。BEGIN_TIME列的值是按照降序显示的,这个视图包含总共576行,跨越4天记录。这个视图和vSUNDOSTAT视图相似。

VSTEMPUNDOSTAT视图重要列的信息:

BEGIN_TIME:Identifies the beginning of the time intervalTXNCOUNT:对应时间内和临时undo 段相关的总共的事务数

MAXCONCURRENCY:在对应时间内,临时对象相关执行并发最多的事务数UNDOBLKCNT:对应时间内,临时undo块的总数

UsCOUNT:对应时间内,临时undo段的个数

NOSPACEERRCNT:对应时间内,临时undo空间不足错误次数

上一篇:Oracle学习笔记二


下一篇:3.Oracle数据结构