Oracle下批量生成ADDM报告

php中文网
发布: 2016-06-07 16:42:47
原创
1465人浏览过

之前写过一篇文章 Oracle 批量生成AWR报告,我们之前每天监控AWR报告,及时消除性能隐患。现在又多了一种手段,生成ADDM报告,听

之前写过一篇文章 oracle 批量生成awr报告(),我们之前每天监控awr报告,及时消除性能隐患。现在又多了一种手段,生成addm报告,,听取下oracle的建议未尝不可。

ADDM能发现定位的问题包括:
.操作系统内存页入页出问题
.由于Oracle负载和非Oracle负载导致的CPU瓶颈问题
.导致不同资源负载的Top SQL语句和对象——CPU消耗、IO带宽占用、潜在IO问题、RAC内部通讯繁忙
.按照PLSQL和JAVA执行时间排的Top SQL语句.
.过多地连接 (login/logoff).
.过多硬解析问题——由于shared pool过小、书写问题、绑定大小不适应、解析失败原因引起的。
.过多软解析问题
.索引查询过多导致资源争用.
.由于用户锁导致的过多的等待时间 (通过包dbms_lock加的锁)
.由于DML锁导致的过多等待时间(例如锁住表了)
.由于管道输出导致的过多等待时间(如通过包dbms_pipe.put进行管道输出)
.由于并发更新同一个记录导致的过多等待时间(行级锁等待)
.由于ITL不够导致的过多等待时间(大量的事务操作同一个数据块)
.系统中过多的commit和rollback(logfile sync事件).
.由于磁盘带宽太小和其他潜在问题(如由于logfile太小导致过多的checkpoint,MTTR设置问题,过多的undo操作等等)导致的IO性能问题I
.对于DBWR进程写数据块,磁盘IO吞吐量不足
.由于归档进程无法跟上redo日至产生的速度,导致系统变慢
.redo数据文件太小导致的问题
.由于扩展磁盘分配导致的争用
.由于移动一个对象的高水位导致的争用问题
.内存太小问题——SGA Target, PGA, Buffer Cache, Shared Pool
.在一个实例或者一个机群环境中存在频繁读写争用的热块
.在一个实例或者一个机群环境中存在频繁读写争用的热对象
.RAC环境中内部通讯问题
.LMS进程无法跟上导致锁请求阻塞
.在RAC环境中由于阻塞和争用导致的实例倾斜
.RMAN导致的IO和CPU问题
.Streams和AQ问题
.资源管理等待事件

Oracle AWR报告生成与查看

在CentOS 6.4下安装Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2

Oracle AWR报告生成步骤

使用方法: 在E盘下面建立addm的目录,将三个文件放入到其中addm.cmd、addm.sql、myaddm.sql.
前提连上的用户需要被赋予两个权限。

grant select any dictionary to user;-----user为生产数据库账号

grant advisor to user;-------user为生产数据库账号

佳蓝在线销售系统(创业版) 佳蓝在线销售
佳蓝在线销售系统(创业版) 佳蓝在线销售

1、对ASP内核代码进行DLL封装,从而大大提高了用户的访问速度和安全性;2、采用后台生成HTML网页的格式,使程序访问速度得到进一步的提升;3、用户可发展下级会员并在下级购买商品时获得差额利润;4、全新模板选择功能;5、后台增加磁盘绑定功能;6、后台增加库存查询功能;7、后台增加财务统计功能;8、后台面值类型批量设定;9、后台财务曲线报表显示;10、完善订单功能;11、对所有传输的字符串进行安全

佳蓝在线销售系统(创业版) 佳蓝在线销售 0
查看详情 佳蓝在线销售系统(创业版) 佳蓝在线销售

1. 文件名:addm.cmd     

 内容:  cmd.exe /c sqlplus username/password@servername @addm.sql

2. 文件名: addm.sql

 内容:

@@E:\addm\myaddm.sql 0 8
@@E:\addm\myaddm.sql 8 12
@@E:\addm\myaddm.sql 12 14
@@E:\addm\myaddm.sql 14 18
@@E:\addm\myaddm.sql 18 24
exit

3. 文件名: myaddm.sql

内容:


set echo off;
set veri off;
set feedback off;
set termout on;
set heading off;
set linesize 300;
var dbid number;
var inst_num number;
var bid number;
var eid number;
var bhour varchar2(10);
var ehour varchar2(10);
var task_name  varchar2(40);
begin
  :bhour      :=  &1;
  :ehour      :=  &2;
  if(length(:bhour)=1)
    then :bhour := '0'||:bhour;
  end if;
  if(length(:ehour)=1)
    then :ehour := '0'||:ehour;
  end if; 
end;
/
begin
select min(snap_id) into :bid from dba_hist_snapshot s
 where (to_char(sysdate-1 , 'yyyy-mm-dd') || ' ' ||:bhour)       to_char(s.end_interval_time, 'yyyy-mm-dd HH24')
      and (to_char(sysdate-1 , 'yyyy-mm-dd') || ' ' ||:ehour) >=
      to_char(s.end_interval_time, 'yyyy-mm-dd HH24');
select max(snap_id) into :eid from dba_hist_snapshot s
 where (to_char(sysdate-1 , 'yyyy-mm-dd') || ' ' ||:bhour)       to_char(s.end_interval_time, 'yyyy-mm-dd HH24')
      and (to_char(sysdate-1 , 'yyyy-mm-dd') || ' ' ||:ehour) >=
      to_char(s.end_interval_time, 'yyyy-mm-dd HH24');
if(:ehour=24)
    then select max(snap_id) into :eid from dba_hist_snapshot s where (to_char(sysdate,'yyyy-mm-dd')||' 00') =to_char(s.end_interval_time,'yyyy-mm-dd HH24');
end if; 
select dbid into :dbid from v$database;
select instance_number into :inst_num from v$instance;
end;
/


column report_name new_value report_name noprint;
select 'PMS_'||:inst_num||'_'||to_char(sysdate-1 ,'yyyymmdd')||'_'||:bhour||'-'||:ehour||'.txt' report_name from dual;
begin
  declare
    id number;
    name varchar2(100);
    descr varchar2(500);
  BEGIN
    name := '';
    descr := 'ADDM run: snapshots [' || :bid || ', '
              || :eid || '], instance ' || :inst_num
              || ', database id ' || :dbid;
    dbms_advisor.create_task('ADDM',id,name,descr,null);
    :task_name := name;
    dbms_advisor.set_task_parameter(name, 'START_SNAPSHOT', :bid);
    dbms_advisor.set_task_parameter(name, 'END_SNAPSHOT', :eid);
    dbms_advisor.set_task_parameter(name, 'INSTANCE', :inst_num);
    dbms_advisor.set_task_parameter(name, 'DB_ID', :dbid);
    dbms_advisor.execute_task(name);
  end;
end;
/

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号