千家信息网

Oracle 学习之 性能优化(十五) ASH、ADDM、AWR

发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,ASH(Active Session History)ASH以V$SESSION为基础,每秒采样一次,记录活动会话等待的事件。不活动的会话不会采样,采样工作由新引入的后台进程MMNL来完成。ASH b
千家信息网最后更新 2025年01月31日Oracle 学习之 性能优化(十五) ASH、ADDM、AWR

ASH(Active Session History)

ASH以V$SESSION为基础,每秒采样一次,记录活动会话等待的事件。不活动的会话不会采样,采样工作由新引入的后台进程MMNL来完成。ASH buffers 的最小值为1MB,最大值不超过30MB.内存中记录数据。期望值是记录一小时的内容。

AWR(Automatic Workload Repository)

自动工作负载信息库

ASH 内存记录数据始终是有限的,为了保存历史数据,引入了自动负载信息库(AutomaticWorkload Repository ,AWR) 由后台进程MMON定期的将ASH信息同步到AWR负载库中。ASH全部写出是不可接受的,所以一般只写入收集的10%的数据量,而且使用direct-path insert完成,尽量减少日志的生成,从而最小化数据库性能影响。

写出到AWR负载库的ASH信息记录在AWR的基础表wrh$active_session_hist中,wrh$active_session_hist是一个分区表,Oracle会自动进行数据清理。

AWR 是Oracle安装好后自动启动的,不需要特别的设置。收集的统计信息存储在SYSAUX表空间SYS模式下,以WRM$_*和WRH$_*的格式命名,默认会保留最近7天收集的统计信息。每个小时将收集到的信息写到数据库中,这一系列操作是由一个叫MMON的进程来完成的。


snapshot的生成周期是每小时,数据保留8天。


手工执行快照

 Exec dbms_workload_repository.create_snapshot;

可以通过视图查询

SQL> select * from DBA_HIST_WR_CONTROL;      DBID SNAP_INTERVAL                                                            RETENTION                                                                TOPNSQL---------- --------------------------------------------------------------------------- --------------------------------------------------------------------------- ------------------------------1417794109 +00000 01:00:00.0                                                         +00008 00:00:00.0                                                           DEFAULT

可以使用DBMS_WORKLOAD_REPOSITORY.MODIFY_SNAPSHOT_SETTINGS来修改snap_interval 和retention。


ADDM (Automatic Database Diagnostic Monitor AWR)

Oracle内部的一个顾问系统,能够自动的完成最数据库的一些优化的建议,给出SQL的优化,索引的创建,统计量的收集等建议。每当生成一次AWR的snapshot时,系统会自动根据当前snapshot和上一次的snapshot,给出一个ADDM报告。ADDM报告只显示系统任务有问题的项目。


生成ash报告

SQL> @?/rdbms/admin/ashrpt.sql

EM->Performance->Average Active Sessions的右上方[Run ASH Report]


生成awr报告

SQL> @?/rdbms/admin/awrrpt.sql

快照之间实例不能关闭。


创建baseline

ExecDBMS_WORKLOAD_REPOSITORY.CREATE_BASELINE(start_snap_id,end_snap_id ,baseline_name);


awr比对报告

@?/rdbms/admin/awrddrpt

RAC全局awr

@?/rdbms/admin/awrgrpt


0