oracle 历史视图视图,看这一篇就够了

历史查看语句

常用的一些:
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

  • 20
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汪灵骅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值