历史查看语句
常用的一些:
dba_hist_sqlstat
dba_hist_active_sess_history
v$active_session_history
dba_hist_active_sess_history
dba_hist_active_sess_history是v$active_session_history的持久化视图。多个触发条件写入dba视图中。
mmon进程把v$active_session_history中的信息采集到基表WRH$_ACTIVE_SESSION_HOSTORY,然后dba_hist_active_sess_history从基表中获取信息,awr从dba_hist_active_sess_history中
每隔10秒钟转储来自v$active_session_history的活动session信息
_ash_disk_filter_ratio(秒)
gv$active_session_history
v$active_session_history使用的是x$ash基表。x$ash数据存放在Shared Pool的ASH Buffer中,大小由隐含参数"_ash_size"决定。
每1秒(_ash_sampling_interval,单位毫秒)将v$session中记录保存到 v$active_session_history 视图中,只会加载非idle会话。
存在内存,重启就会消失。用做ASH报表。
重要!!!
1.mmnl进程从gv$session视图(从X$KSUSE基表获取)采集信息到ash buffers中,并且被获取到X$ASH基表中,默认1秒一次(_ash_sampling_interval,单位毫秒)。
2.gv$active_session_history视图从X$ASH基表读取数据,由mmon进程将gv$active_session_history视图信息持久化到wrh$_active_session_history基表中。
3.dba_hist_active_sess_history视图从wrh$_active_session_history基表读取数据,默认10秒一次(_ash_disk_filter_ratio,秒)。
4.awr报告数据从dba_hist_active_sess_history视图获取。
其中x$ksuse是gv$session视图所使用的基表,同样可以通过前面的方法查到(set autotrace trace)。首先mmnl进程从gv$session动态性能视图中采集信息,默认每秒采集一次,然后将采集的信息写入到ash buffers中,此时活动会话信息已经进入到x$ash基表中,然后gv$active_session_history视图从x$ash基表中读取数据,mmon进程负责对gv$active_session_history视图中的信息进行持久化,持久化到wrh$_active_session_history基表中,而dba_hist_active_sess_history视图中的数据又是来源于wrh$_active_session_history基表。可以看到ash相关的部分除了需要mmon进程进行持久化到awr,实际上正如前边所说的,ash 和 awr是两个不同的东西,不能混为一谈。
最后列出几个和ASH相关的隐含参数:
• _ash_disk_filter_ratio
采样到DBA_HIST_ACTIVE_SESS_HISTORY中的频率,默认为10s一次
• _ash_disk_write_enable
开启采样到DBA_HIST_ACTIVE_SESS_HISTORY,设置为false则即使创建快照也不会刷新数据到DBA_HIST_ACTIVE_SESS_HISTORY视图中
• _ash_eflush_trigger
ASH buffers满了多少以后会写出,默认为66%
• _ash_enable
禁用和启用ASH采样
• _ash_sample_all
设置为true,则所有会话都会被采样,包括处于空闲等待的会话,默认是false
• _ash_sampling_interval
ASH采样间隔时间,默认为1000ms
• _ash_size
ASH buffers大小
查看_ash_size如果超过256m可能触发bug20185439(2268127.1)
如果_ash_size过小(默认1m),可能导致刷新次数过多,造成性能瓶颈。
设置参数会刷新一次。
建议大小为 total_size的1.5倍
select total_size/1024/1024,awr_flush_emergency_count from v$ash_info;
oracle建议多次出现此问题再解决 Active Session History (ASH) performed an emergency flush
ash是否存在异常刷新(awr_flush_emergency_count)
select total_size/1024/1024,awr_flush_emergency_count from v$ash_info;
alter system set “_ash_size”=2048618 sid=‘*’ scope=spfile;
参考、领悟:
https://www.modb.pro/db/40286
https://www.cnblogs.com/andy6/p/8301933.html
https://blog.csdn.net/JiekeXu/article/details/129434277