那些被你忽略的性能 - Oracle Redo的产生场景及优化

冷菠

冷菠,资深DBA,著有《Oracle高性能自动化运维》,有近10年的数据库运维、团队管理以及培训经验。擅长数据库备份恢复、数据库性能诊断优化以及数据库自动化运维等。目前致力于大数据、智能一体化、开源云计算等领域的佳实践探索。

Oracle Redo是以条目(Redo record)的形式记录数据库的所有更改操作。这些更改包括数据库物理文件的更改,数据库运行状况更改,后台进程的写操作,DML事务操作,数据字典DDL操作,数据库内部递归调用等。其中,最主要的原因是DML事务的操作。

本文将分析Redo对于数据库DML操作的记录信息,并提出通过减少Redo条目达到优化Redo,提高数据库性能的方案。

DML事务相关的数据库更改有哪些?

  1. 数据块更改;
  2. 回滚段数据块镜像更新;
  3. 数据库内部信息更新(数据字典表更新)。

我们可以通过日志挖掘获取到数据库更改的相关信息,如下:

可以看到,Redo中记录了DML事物的数据块更改、回滚段更新等信息。

如何来减少Redo的产生,从而达到优化Redo的目的

  1. 减少索引键更新操作;
  2. 大表(键)更新操作;
  3. 使用Direct Load加载数据;
  4. 使用Nologging进行特定操作;
  5. 使用临时表(Temporary Table);
  6. 使用外部表(External Table);
  7. 批量化处理DML业务程序;
  8. 减少事务Commit次数,采用组提交的方式;
  9. 减少Select For Update显示锁定,可以明显减少Redo产生;
  10. 减少表记录的数量规模(利用分区路由架构分区裁剪特性),例如使用分区、分表、分库等策略;
  11. 减少不必要的DML操作可以减少Redo产生,例如改写、整合SQL程序,优化业务逻辑。

通过示例验证优化的可行性

采用组提交减少Redo的产生:

不采用组提交插入数据:

采用组提交(提交一次)插入数据:

从上述数据可以看出:

不采用组提交产生Redo :9268980;

采用组提交产生Redo: 5241596;

组提交大大减少了Redo的产生:4027384(9268980-5241596)。

采用临时表可以减少Redo产生:

采用普通表插入数据:

采用全局临时表插入数据:

从上述数据可以看出:

普通表产生Redo:5479300;

全局临时表产生Redo:1607268;

全局临时表大大减少了Redo产生:3872032(5479300-1607268)。

论证结论

可以看到,采用组提交和使用临时表都能有效的减少Redo的产生,从而提升了数据库性能。有兴趣的读者可以尝试采用其余措施进行扩展验证。

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2017-09-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏数据库

不得不看,只有专家才知道的17个SQL查询提速秘诀!

“ 除非你遵循本文介绍的这些技巧,否则很容易编写出减慢查询速度或锁死数据库的数据库代码。 ? 由于数据库领域仍相对不成熟,每个平台上的 SQL 开发人员都在苦苦...

1826
来自专栏PHP技术

WordPress的可拓展性初探(一)

作者:西瓜玩偶(racnil070512 at hotmail dot com) WordPress是一个时下非常流行的网络信息发布平台,它的特性之一便是极强...

2859
来自专栏数据和云

拨云见日—深入解析Oracle TX 行锁(上)

Balance is the only key to optimize. 平衡是性能优化的核心标准。 在刚刚过去不久的第七届数据技术嘉年华上,性能优化专家怀晓明...

3409
来自专栏青玉伏案

OracleDBA之表管理

  下面是Oracle表管理的部分,用到的测试表是oracle数据库中scott用户下的表做的测试,有的实验也用到了hr用户的数据,以下这些东西是我的麦库上存的...

1828
来自专栏程序你好

互联网MySQL数据库应用潜规则

1002
来自专栏杨建荣的学习笔记

一条update语句的优化探索(r9笔记第80天)

今天经开发同学反馈,发现有一些update语句阻塞了部分业务流程,为什么说一些而不是一条,是因为这些update语句都在一个存储过程中,语句结构相仿,真有一种一...

3174
来自专栏葬爱家族

Android高德之旅(13)公交搜索

在LBS系统中怎能少了公交这个角色,大多数城市中,主要的公共交通工具还是公交车,高德地图当然会有相应的api来查询公交信息,这篇文章就来记录下公交信息查询。

542
来自专栏Rgc

提高查询数据速度

在实际项目中,通过设计表架构时,设计系统结构时,查询数据时综合提高查询数据效率 1.适当冗余 数据库在设计时遵守三范式,同时业务数据(对数据的操作,比如资料...

3488
来自专栏数据和云

SQL之美 - Oracle 子查询优化系列精讲

题记:SQL优化及SQL审核,是从源头解决性能问题的根本手段,无论是开发人员还是DBA,都应当持续深入的学习SQL开发技能,从而为解决性能问题打下根基。 本系列...

2813
来自专栏Kevin-ZhangCG

什么是事务?事务的四个特性以及事务的隔离级别

2059

扫描关注云+社区