学习动态性能表 第十五篇--V$ROLLSTAT

 

学习动态性能表

15--V$ROLLSTAT 

  本视图自启动即保持并记录各回滚段统计项。在学习本视图之前,我们先来了解一下回滚段(rollback segment)的相关概念:

回滚段概述

  回滚段用于存放数据修改之前的值(包括数据修改之前的位置和值)。回滚段的头部包含正在使用的该回滚段事务的信息。一个事务只能使用一个回滚段来存放它的回滚信息,而一个回滚段可以存放多个事务的回滚信息。

回滚段的作用

  1。事务回滚:当事务修改表中数据的时候,该数据修改前的值(即前影像)会存放在回滚段中,当用户回滚事务(ROLLBACK)时,ORACLE将会利用回滚段中的数据前影像来将修改的数据恢复到原来的值。

  2。事务恢复:当事务正在处理的时候,例程失败,回滚段的信息保存在重做日志文件中,ORACLE将在下次打开数据库时利用回滚来恢复未提交的数据。

  3。读一致性:当一个会话正在修改数据时,其他的会话将看不到该会话未提交的修改。而且,当一个语句正在执行时,该语句将看不到从该语句开始执行后的未提交的修改(语句级读一致性)。当ORACLE执行SELECT语句时,ORACLE依照当前的系统改变号(SYSTEM CHANGE NUMBER-SCN)来保证任何前于当前SCN的未提交的改变不被该语句处理。可以想象:当一个长时间的查询正在执行时,若其他会话改变了该查询要查询的某个数据块,ORACLE将利用回滚段的数据前影像来构造一个读一致性视图。

事务级的读一致性

  ORACLE一般提供SQL语句级(SQL STATEMENT LEVEL)的读一致性,可以用以下语句来实现事务级的读一致性。

  SET TRANSACTION READ ONLY;

  或:

  SET TANNSACTION SERIALIZABLE;

  以上两个语句都将在事务开始后提供读一致性。需要注意的是,使用第二个语句对数据库的并发性和性能将带来影响。

回滚段的种类

  1。系统回滚段:当数据库创建后,将自动创建一个系统回滚段,该回滚段只用于存放系统表空间中对象的前影像。

  2。非系统回滚段:拥有多个表空间的数据库至少应该有一个非系统回滚段,用于存放非系统表空间中对象的数据前影像。非系统回滚段又分为私有回滚段和公有回滚段,私有回滚段应在参数文件的ROLLBACK SEGMENTS参数中列出,以便例程启动时自动使其在线(ONLINE)。公有回滚段一般在OPS(ORACLE并行服务器)中出现,将在例程启动时自动在线。

  3。DEFERED回滚段:该回滚段在表空间离线(OFFLINE)时由系统自动创建,当表空间再次在线(ONLINE)时由系统自动删除,用于存放表空间离线时产生的回滚信息。

回滚段的使用

  分配回滚段:当事务开始时,ORACLE将为该事务分配回滚段,并将拥有最少事务的回滚段分配给该事务。事务可以用以下语句申请指定的回滚段:

  SET TRANSTRACTION USE ROLLBACK SEGMENT rollback_segment

  事务将以顺序,循环的方式使用回滚段的区(EXTENTS),当当前区用满后移到下一个区。几个事务可以写在回滚段的同一个区,但每个回滚段的块只能包含一个事务的信息。

  例如(两个事务使用同一个回滚段,该回滚段有四个区):

  1、事务在进行中,它们正在使用回滚段的第三个区;

  2、当两个事务产生更多的回滚信息,它们将继续使用第三个区;

  3、当第三个区满后,事务将写到第四个区,当事务开始写到一个新的区时,称为翻转(WRAP);

  4、当第四个区用满时,如果第一个区是空闲或非活动(使用该区的所有事务完成而没有活动的事务)的,事务将接着使用第一个区。

回滚段的扩张(EXTEND

  当当前回滚段区的所有块用完而事务还需要更多的回滚空间时,回滚段的指针将移到下一个区。当最后一个区用完,指针将移到第一个区的前面。回滚段指针移到下一个区的前提是下一个区没有活动的事务,同时指针不能跨区。当下一个区正在使用时,事务将为回滚段分配一个新的区,这种分配称为回滚段的扩展。回滚段将一直扩展到该回滚段区的个数到达回滚段的参数MAXEXTENTS的值时为止。

回滚段的回收和OPTIMAL参数

  OPTIMAL参数指明回滚段空闲时收缩到的位置,指明回滚段的OPTIMAL参数可以减少回滚段空间的浪费。

V$ROLLSTAT中的常用列

l         USN:回滚段标识

l         RSSIZE:回滚段默认大小

l         XACTS:活动事务数

在一段时间内增量用到的列

l         WRITES:回滚段写入数(单位:bytes)

l         SHRINKS:回滚段收缩次数

l         EXTENDS:回滚段扩展次数

l         WRAPS:回滚段翻转(wrap)次数

l         GETS:获取回滚段头次数

l         WAITS:回滚段头等待次数

V$ROLLSTAT中的连接列

Column                                    View                                        Joined Column(s)

--------------                               -----------------------                   ------------------------

USN                                V$ROLLNAME                 USN

注意:

  通过花费时间除以翻转次数,你可以得到一次回滚段翻转(wrap)的平均用时。此方法常用于在长查询中指定合适的回滚段大小以避免'Snapshot Too Old'错误。同时,通过查看extends和shrinks列可以看出optimal是否需要增加。

示例:

1.查询回滚段的信息。所用数据字典:DBA_ROLLBACK_SEGS,可以查询的信息:回滚段的标识(SEGMENT_ID)、名称(SEGMENT_NAME)、所在表空间(TABLESPACE_NAME)、类型(OWNER)、状态(STATUS)。

select * from DBA_ROLLBACK_SEGS

2.查看回滚段的统计信息:

SELECT n.name, s.extents, s.rssize, s.optsize, s.hwmsize, s.xacts, s.status

 FROM v$rollname n, v$rollstat s

 WHERE n.usn = s.usn;

3.查看回滚段的使用情况,哪个用户正在使用回滚段的资源:

select s.username, u.name

 from v$transaction t, v$rollstat r, v$rollname u, v$session s

 where s.taddr = t.addr

   and t.xidusn = r.usn

   and r.usn = u.usn

 orderby s.username;

时间: 2024-11-08 21:51:22

学习动态性能表 第十五篇--V$ROLLSTAT的相关文章

学习动态性能表 第十八篇--V$SYSTEM_EVENT

  学习动态性能表 第18篇--V$SYSTEM_EVENT  本视图概括了实例各项事件的等待信息.v$session_wait显示了系统的当前等待项,v$system_event则提供了自实例启动后各个等待事件的概括.常用于获取系统等待信息的历史影象.而通过两个snapshot获取等待项增量,则可以确定这段时间内系统的等待项. V$SYSTEM_EVENT中的常用列 l         EVENT:等待事件名称 l         TOTAL_WAITS:此项事件总等待次数 l        

学习动态性能表 第十九篇--V$UNDOSTAT

  学习动态性能表 第19篇--V$UNDOSTAT  本视图监控当前实例中undo空间以及事务如何运行.并统计undo空间开销,事务开销以及实例可用的查询长度. V$UNDOSTAT中的常用列 l         Endtime:以10分钟为间隔的结束时间 l         UndoBlocksUsed:使用的undo块总数 l         TxnConcurrency:事务并发执行的最大数 l         TxnTotal:在时间段内事务执行总数 l         QueryLe

学习动态性能表 第十六篇--V$ROWCACHE

  学习动态性能表 第16篇--V$ROWCACHE  本视图显示数据字典缓存(也叫rowcache)的各项统计.每一条记录包含不同类型的数据字典缓存数据统计,注意数据字典缓存有层次差别,因此同样的缓存名称可能不止一次出现. V$ROWCACHE常用列 l         PARAMETER:缓存名 l         COUNT:缓存项总数 l         USAGE:包含有效数据的缓存项数 l         GETS:请求总数 l         GETMISSES:请求失败数 l  

学习动态性能表 第十四篇--V$PARAMETER&V$SYSTEM_PARAMETER

  学习动态性能表 第14篇--V$PARAMETER&V$SYSTEM_PARAMETER  这两个视图列出的各参数项名称以及参数值.V$PARAMETER显示执行查询的session的参数值.V$SYSTEM_PARAMETER视图则列出实例的参数值. 例如,下列查询显示执行查询的session的SORT_AREA_SIZE参数值: SELECTvalue  FROM V$PARAMETER  WHEREname = 'sort_area_size'; 呵呵,可能有朋友还是不明白v$para

学习动态性能表 第十二篇--V$DB_OBJECT_CACHE

  学习动态性能表 第12篇--V$DB_OBJECT_CACHE  本视图提供对象在library cache(shared pool)中对象统计,提供比v$librarycache更多的细节,并且常用于找出shared pool中的活动对象. v$db_object_cache中的常用列: l         OWNER:对象拥有者 l         NAME:对象名称 l         TYPE:对象类型(如,sequence,procedure,function,package,pa

学习动态性能表 第十篇--V$SESSION_LONGOPS

  学习动态性能表 第十篇--V$SESSION_LONGOPS  本视图显示运行超过6秒的操作的状态.包括备份,恢复,统计信息收集,查询等等. 要监控查询执行进展状况,你必须使用cost-based优化方式,并且: l         设置TIMED_STATISTICS或SQL_TRACE参数值为true. l         通过ANALYZE或DBMS_STATS数据包收集对象统计信息. 你可以通过DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS过程添加

学习动态性能表 第二十篇--V$WAITSTAT

  学习动态性能表 第20篇--V$WAITSTAT  本视图保持自实例启动所有的等待事件统计信息.常用于当你发现系统存在大量的"buffer busy waits"时据此做出适当调整. V$WAITSTAT中的常用列 l         CLASS:块类别 l         WAITS:本类块的等待次数 l         TIME:本类块的总等待时间 等待发生的原因: 1.undo段头部:没有足够的回滚段 2.数据段头部/数据段空闲列:空闲列争夺 3.数据块冲突 4.缓存存在大量

学习动态性能表 第五篇--V$SESSION

  学习动态性能表 第五篇--V$SESSION  在本视图中,每一个连接到数据库实例中的session都拥有一条记录.包括用户session及后台进程如DBWR,LGWR,arcchiver等等. V$SESSION中的常用列   V$SESSION是基础信息视图,用于找寻用户SID或SADDR.不过,它也有一些列会动态的变化,可用于检查用户.如例: SQL_HASH_VALUE,SQL_ADDRESS:这两列用于鉴别默认被session执行的SQL语句.如果为null或0,那就说明这个ses

学习动态性能表 第七篇--V$PROCESS

  学习动态性能表 第七篇--V$PROCESS  本视图包含当前系统oracle运行的所有进程信息.常被用于将oracle或服务进程的操作系统进程ID与数据库session之间建立联系.在某些情况下非常有用: 1.         如果数据库瓶颈是系统资源(如:cpu,内存),并且占用资源最多的用户总是停留在某几个服务进程,那么进行如下诸项: l         找出资源进程 l         找出它们的session,你必须将进程与会话联系起来. l         找出为什么sessio