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

 

 

 

转载于:https://www.cnblogs.com/taowang2016/archive/2013/04/18/3028899.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值