设为首页 收藏本站
查看: 677|回复: 0

[经验分享] Oracle表变化趋势追踪记录(原创)

[复制链接]

尚未签到

发表于 2016-7-29 11:10:54 | 显示全部楼层 |阅读模式
  这几天数据库上的用户表空间疯涨,一天的增长量达到了20~30GB,平时就4~5GB的增长量。问了开发商,他们也说不出个所以然。PS:那些鸟开发商,现在我已经对他们绝望了,什么都不知道。情急之下直接对该表空间进行了扩容,问题总算解决了。事后总想弄个明白,想知道是那张表导致的表空间增长如此之快,以免下次出现同样的问题又是不知所措。
  google了一番后发现DBA_HIST_SEG_STAT可以看出对象的使用趋势
构造如下SQL查询出每个时间段内数据库对象的增长量,其中DB_BLOCK_CHANGES_DELTA为块个数
  select c.SNAP_ID,to_char(c.END_INTERVAL_TIME,'yyyy-mm-dd') SNAP_TIME,a.OWNER ,a.OBJECT_NAME, a.OBJECT_TYPE, b.DB_BLOCK_CHANGES_DELTA
from dba_objects a,
(select SNAP_ID,obj#,DB_BLOCK_CHANGES_DELTA from DBA_HIST_SEG_STAT where DB_BLOCK_CHANGES_DELTA > 20000 order by snap_id desc, DB_BLOCK_CHANGES_DELTA desc) b,
DBA_HIST_SNAPSHOT c
where a.object_id=b.obj# and object_type='TABLE' and b.SNAP_ID=c.SNAP_ID
order by DB_BLOCK_CHANGES_DELTA

  下面的SQL查询出某个时间段内,数据库对象的变化大小,单位以换算成GB

  select a.OBJECT_NAME,to_char(c.END_INTERVAL_TIME,'yyyy-mm-dd') SNAP_TIME, sum(b.DB_BLOCK_CHANGES_DELTA)/1024/1024 GB from dba_objects a,(select SNAP_ID,obj#,DB_BLOCK_CHANGES_DELTA from DBA_HIST_SEG_STAT where DB_BLOCK_CHANGES_DELTA > 20000 order by snap_id desc, DB_BLOCK_CHANGES_DELTA desc) b,DBA_HIST_SNAPSHOT c
where a.object_id=b.obj# and object_type='TABLE' and b.SNAP_ID=c.SNAP_ID
group by a.OBJECT_NAME,c.END_INTERVAL_TIME
order by GB

简单介绍下DBA_HIST_SEG_STAT
  DBA_HIST_SEG_STAT视图内记录了数据库实例启动以来段的变化信息,该视图的数据来自于v$segstat
ColumnDatatypeNULLDescriptionSNAP_IDNUMBER Unique snapshot IDDBIDNUMBER Database ID for the snapshotINSTANCE_NUMBERNUMBER Instance number for the snapshotTS#NUMBER Tablespace numberOBJ#NUMBER Dictionary object numberDATAOBJ#NUMBER Data object numberLOGICAL_READS_TOTALNUMBER Cumulative value for logical readsLOGICAL_READS_DELTANUMBER Delta value for logical readsBUFFER_BUSY_WAITS_TOTALNUMBER Cumulative value for buffer busy waitsBUFFER_BUSY_WAITS_DELTANUMBER Delta value for buffer busy waitsDB_BLOCK_CHANGES_TOTALNUMBER Cumulative value for db block changesDB_BLOCK_CHANGES_DELTANUMBER Delta value for db block changesPHYSICAL_READS_TOTALNUMBER Cumulative value for physical readsPHYSICAL_READS_DELTANUMBER Delta value for physical readsPHYSICAL_WRITES_TOTALNUMBER Cumulative value for physical writesPHYSICAL_WRITES_DELTANUMBER Delta value for physical writesPHYSICAL_READS_DIRECT_TOTALNUMBER Cumulative value for physical reads directPHYSICAL_READS_DIRECT_DELTANUMBER Delta value for physical reads directPHYSICAL_WRITES_DIRECT_TOTALNUMBER Cumulative value for physical writes directPHYSICAL_WRITES_DIRECT_DELTANUMBER Delta value for physical writes directITL_WAITS_TOTALNUMBER Cumulative value for ITL waitsITL_WAITS_DELTANUMBER Delta value for ITL waitsROW_LOCK_WAITS_TOTALNUMBER Cumulative value for row lock waitsROW_LOCK_WAITS_DELTANUMBER Delta value for row lock waitsGC_CR_BLOCKS_SERVED_TOTALNUMBER Cumulative value for global cache CR blocks servedGC_CR_BLOCKS_SERVED_DELTANUMBER Delta value for global cache CR blocks servedGC_CU_BLOCKS_SERVED_TOTALNUMBER Cumulative value for global cache current blocks servedGC_CU_BLOCKS_SERVED_DELTANUMBER Delta value for global cache current blocks servedGC_BUFFER_BUSY_TOTALNUMBER Cumulative value for global cache buffer busyGC_BUFFER_BUSY_DELTANUMBER Delta value for global cache buffer busyGC_CR_BLOCKS_RECEIVED_TOTALNUMBER Cumulative value for global cache CR blocks receivedGC_CR_BLOCKS_RECEIVED_DELTANUMBER Delta value for global cache CR blocks receivedGC_CU_BLOCKS_RECEIVED_TOTALNUMBER Cumulative value for global cache current blocks receivedGC_CU_BLOCKS_RECEIVED_DELTANUMBER Delta value for global cache current blocks receivedSPACE_USED_TOTALNUMBER Cumulative value for space usedSPACE_USED_DELTANUMBER Delta value for space usedSPACE_ALLOCATED_TOTALNUMBER Cumulative value for space allocatedSPACE_ALLOCATED_DELTANUMBER Delta value for space allocatedTABLE_SCANS_TOTALNUMBER Cumulative value for table scansTABLE_SCANS_DELTANUMBER Delta value for table scans  顺便说一句DBA_HIST_TBSPC_SPACE_USAGE视图可以监控表空间的使用趋势
  
  感谢杨帅军的指点
  参考至:http://oracle.erkansaka.org/2007/09/how-to-determine-tables-with-highest.html
              http://docs.oracle.com/cd/B19306_01/server.102/b14237/statviews_3165.htm
  本文原创,转载请注明出处、作者
如有错误,欢迎指正
  邮箱:czmcj@163.com

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-251138-1-1.html 上篇帖子: Oracle KEEP池的CACHE特点 下篇帖子: oracle 块延迟清除(delayed block cleanout)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表