zoukankan      html  css  js  c++  java
  • Statspack报告中Rollback per trans过高怎么办

    http://digifish.i.sohu.com/blog/view/41915667.htm

    olivenan网友在itpub上提问,statspack报表中的Rollback per transaction %达到93.97%,对系统是否有影响,偶以前也曾经也遇到过这个问题,现将这个问题做个解答,希望对这个问题比较困惑的同学有所帮助,实际情况就是:statsapck报表中的rollback per transaction%比例过高对系统没有什么不利影响。

    如果想对这个问题有所理解,必须对以下两个问题的概念比较清楚:
    1 了解user rollback与transaction rollback的区别
    2 了解Rollback per transaction%的计算公式

    想清楚地理解第1个问题,请看biti是如何说明的

    user rollback 表示用户发出了 rollback 命令并不代表一定有 数据变化(事务)
    
    sys@OCN>l
    1* select * from v$sysstat where name like '%rollback%'
    sys@OCN>/
    
    STATISTIC# NAME CLASS VALUE
    ---------- ---------------------------------------------------------------- ---------- ----------
    5 user rollbacks 1 3
    162 transaction tables consistent read rollbacks 128 0
    166 rollbacks only - consistent read gets 128 62
    167 cleanouts and rollbacks - consistent read gets 128 0
    171 rollback changes - undo records applied 128 8
    172 transaction rollbacks 128 4
    
    6 rows selected.
    
    sys@OCN>rollback;
    
    Rollback complete.
    
    sys@OCN>/
    
    Rollback complete.
    
    sys@OCN>select * from v$sysstat where name like '%rollback%'
    2 ;
    
    STATISTIC# NAME CLASS VALUE
    ---------- ---------------------------------------------------------------- ---------- ----------
    5 user rollbacks 1 5
    162 transaction tables consistent read rollbacks 128 0
    166 rollbacks only - consistent read gets 128 62
    167 cleanouts and rollbacks - consistent read gets 128 0
    171 rollback changes - undo records applied 128 8
    172 transaction rollbacks 128 4
    
    6 rows selected.
    
    sys@OCN>roll;
    Rollback complete.
    sys@OCN>select * from v$sysstat where name like '%rollback%'
    2 ;
    
    STATISTIC# NAME CLASS VALUE
    ---------- ---------------------------------------------------------------- ---------- ----------
    5 user rollbacks 1 6
    162 transaction tables consistent read rollbacks 128 0
    166 rollbacks only - consistent read gets 128 62
    167 cleanouts and rollbacks - consistent read gets 128 0
    171 rollback changes - undo records applied 128 8
    172 transaction rollbacks 128 4
    
    6 rows selected.
    
    sys@OCN>
    
    user rollback 发生变化 但 transaction rollback 没有变化

    第2个问题根据statspack的sql代码很容易知道它们是如何计算的.在$ORACLE_HOME/rdbms/admin/sprepins.sql中可找到代码:

    1 计算rollback per transaction%的公式:
    Rollback per transaction %:' dscr, round(100*:urol/:tran,2) pctval
    2 计算:urol与:tran的公式:
    在这里大家注意:ucal与:urol这两个绑定变量,查$ORACLE_HOME/rdbms/admin/spcpkg.sql中可以找到代码:
    begin /* main procedure body of STAT_CHANGES */
    lhtr := LIBRARYCACHE_HITRATIO;
    bfwt := BUFFER_WAITS;
    lhr := LATCH_HITRATIO;
    chng := SYSDIF('db block changes');
    ucal := SYSDIF('user calls');
    urol := SYSDIF('user rollbacks');
    ucom := SYSDIF('user commits');
    tran := ucom + urol;
    实际上tran就是tran:=user commits+user rollbacks,那最终的Rollback per transaction计算公式就应该是:
    Rollback per transaction% = user rollback/(user rollback+user commit);

    其实这是statspack报表选取的计算方式用误,statspack report中的回滚率是通过user rollbacks/(user rollbacks+user commits),如果用transaction rollbacks/(transaction rollbacks+user commits)就没错啦,它这样计算,肯定是并不想区分user rollbacks与transaction rollbacks,但实际在某些环境下,user rollbacks与transaction rollbacks确实存在较大的差异...

    你可以考虑找找看谁在做大量的rollback:

    SELECT s.sid,program,machine,st.Value rollback_count
    FROM v$session s ,v$sesstat st ,v$statname n
    WHERE n.statistic# = st.statistic#
    AND n.NAME = 'user rollbacks'
    AND s.sid = st.sid
    AND st.Value > 0
    ORDER BY st.Value desc

     

    使用该语句查询做大量的rollback的sql:

    SELECT st.Value rollback_count,substr(trim(c.sql_text),1,40)||'...'
    FROM v$session s ,v$sesstat st ,v$statname n, v$process b, v$sqlarea c
    WHERE n.statistic# = st.statistic#
    AND n.NAME = 'user rollbacks'
    AND s.sid = st.sid
    AND st.Value > 0
    and b.addr = s.paddr
    AND s.sql_address = c.address(+)
    ORDER BY st.Value desc

     

  • 相关阅读:
    事件委托
    a标签深入研究
    windows查看端口号
    什么是WCM
    map key循环
    用Myeclipse打war包
    myeclipse 8.510.0 安装 svn 方法
    SVN使用&CVS使用
    MyEclipse 字体大小 字体颜色
    什么是Quickr
  • 原文地址:https://www.cnblogs.com/taowang2016/p/3028899.html
Copyright © 2011-2022 走看看