参考文献:

Oracle11g 统计信息(一)-----统计信息自动收集任务

背景:

在使用cacti监控oracle数据库IO的时候发现每天晚上10点钟的时候oracle数据库读写明显增加,如下图所示:

对这个问题,后来查了一下是因为oracle在运行一个信息自动收集任务。oracle 11g中统计信息自动收集任务的名称是auto optimizer stats collection。11g中自动任务默认的执行时间窗口(oracle时间窗口介绍)为:

  • 周一到周五是晚上10点开始到2点结束
  • 周末是早上六点,持续20个小时。

1、查看自动收集任务及状态

select client_name,status from Dba_Autotask_Client where client_name='auto optimizer stats collection';

2、停止自动收集任务

--关闭信息自动收集任务
BEGIN
DBMS_AUTO_TASK_ADMIN.DISABLE(
client_name => 'auto optimizer stats collection',
operation => NULL, window_name => NULL);
END;
/ PL/SQL procedure successfully completed. --再次查询
select client_name,status from Dba_Autotask_Client where client_name='auto optimizer stats collection';
CLIENT_NAME STATUS
---------------------------------------------------------------- --------
auto optimizer stats collection DISABLED

但是此时再查询DBA_ATUOTASK_TASK视图时,显示该任务状态还是ENABLED

select client_name,status from dba_autotask_task where client_name='auto optimizer stats collection';
CLIENT_NAME STATUS
---------------------------------------------------------------- --------
auto optimizer stats collection ENABLED

Oracle给出的解释是在现在的版本中(11.1 to 11.2)一个client对应一个task,但是在将来的版本中会出现多个client会对应一个task,所以一个client被disabled了,不会改变task的状态。[ID 858852.1]

3、启动自动收集任务

 BEGIN
DBMS_AUTO_TASK_ADMIN.ENABLE(
client_name => 'auto optimizer stats collection',
operation => NULL, window_name => NULL);
END;
/
PL/SQL procedure successfully completed.
--再次查询
select client_name,status from Dba_Autotask_Client where client_name='auto optimizer stats collection';
CLIENT_NAME STATUS
---------------------------------------------------------------- --------
auto optimizer stats collection ENABLED

4、查看自动收集任务历史执行状态

SELECT client_name, window_name, jobs_created, jobs_started, jobs_completed FROM dba_autotask_client_history WHERE client_name like '%stats%';
       CLIENT_NAME    WINDOW_NAME    JOBS_CREATED    JOBS_STARTED    JOBS_COMPLETED
1 auto optimizer stats collection FRIDAY_WINDOW 1 1 1
2 auto optimizer stats collection FRIDAY_WINDOW 1 1 1
3 auto optimizer stats collection FRIDAY_WINDOW 1 1 1
4 auto optimizer stats collection FRIDAY_WINDOW 1 1 1
5 auto optimizer stats collection MONDAY_WINDOW 1 1 1
6 auto optimizer stats collection MONDAY_WINDOW 1 1 1
7 auto optimizer stats collection MONDAY_WINDOW 1 1 1
8 auto optimizer stats collection MONDAY_WINDOW 1 1 1
9 auto optimizer stats collection SATURDAY_WINDOW 5 5 5
10 auto optimizer stats collection SATURDAY_WINDOW 5 5 5
11 auto optimizer stats collection SATURDAY_WINDOW 5 5 5
12 auto optimizer stats collection SATURDAY_WINDOW 5 5 5
13 auto optimizer stats collection SUNDAY_WINDOW 5 5 5
14 auto optimizer stats collection SUNDAY_WINDOW 5 5 5
15 auto optimizer stats collection SUNDAY_WINDOW 5 5 5
16 auto optimizer stats collection SUNDAY_WINDOW 5 5 5
17 auto optimizer stats collection THURSDAY_WINDOW 1 1 1
18 auto optimizer stats collection THURSDAY_WINDOW 1 1 1
19 auto optimizer stats collection THURSDAY_WINDOW 1 1 1
20 auto optimizer stats collection THURSDAY_WINDOW 1 1 1
21 auto optimizer stats collection TUESDAY_WINDOW 1 1 1
22 auto optimizer stats collection TUESDAY_WINDOW 1 1 1
23 auto optimizer stats collection TUESDAY_WINDOW 1 1 1
24 auto optimizer stats collection TUESDAY_WINDOW 1 1 1
25 auto optimizer stats collection TUESDAY_WINDOW 1 1 1
26 auto optimizer stats collection WEDNESDAY_WINDOW 1 1 1
27 auto optimizer stats collection WEDNESDAY_WINDOW 1 1 1
28 auto optimizer stats collection WEDNESDAY_WINDOW 1 1 1
29 auto optimizer stats collection WEDNESDAY_WINDOW 1 1 1
30 auto optimizer stats collection WEDNESDAY_WINDOW 1 1 1

通过时间窗口名称可以看出是周几执行的,在时间窗口内创建了几次job,执行了几次job,当然可以加上window_start_time来查看具体执行的日期。

5、查看自动收集任务执行时间窗口

select WINDOW_NAME, WINDOW_NEXT_TIME , WINDOW_ACTIVE,OPTIMIZER_STATS from DBA_AUTOTASK_WINDOW_CLIENTS order by WINDOW_NEXT_TIME ;
       WINDOW_NAME    WINDOW_NEXT_TIME    WINDOW_ACTIVE    OPTIMIZER_STATS
1 THURSDAY_WINDOW 07-AUG-14 10.00.00.000000 PM +08:00 FALSE ENABLED
2 FRIDAY_WINDOW 08-AUG-14 10.00.00.000000 PM +08:00 FALSE ENABLED
3 SATURDAY_WINDOW 09-AUG-14 06.00.00.000000 AM +08:00 FALSE ENABLED
4 SUNDAY_WINDOW 10-AUG-14 06.00.00.000000 AM +08:00 FALSE ENABLED
5 MONDAY_WINDOW 11-AUG-14 10.00.00.000000 PM +08:00 FALSE ENABLED
6 TUESDAY_WINDOW 12-AUG-14 10.00.00.000000 PM +08:00 FALSE ENABLED
7 WEDNESDAY_WINDOW 13-AUG-14 10.00.00.000000 PM +08:00 FALSE ENABLED

6、查询自动收集任务正在执行的JOB

select client_name, JOB_SCHEDULER_STATUS from DBA_AUTOTASK_CLIENT_JOB where client_name='auto optimizer stats collection';

这个查询没有结果也很正常,只有job正在运行时,该查询才有结果。

7、与时间窗口相关的视图
查询自动收集任务所属时间窗口组

select client_name,window_group from dba_autotask_client where client_name='auto optimizer stats collection';
       CLIENT_NAME    WINDOW_GROUP
1 auto optimizer stats collection ORA$AT_WGRP_OS

查询自动收集任务所属时间窗口组详细信息

select * from dba_scheduler_window_groups where window_group_name='ORA$AT_WGRP_OS';
       WINDOW_GROUP_NAME    ENABLED    NUMBER_OF_WINDOWS    NEXT_START_DATE    COMMENTS
1 ORA$AT_WGRP_OS TRUE 7 07-AUG-14 10.00.00.000000 PM +08:00 auto optimizer stats collection

查看自动收集任务所属时间窗口组包含的子时间窗口

select * from dba_scheduler_wingroup_members where window_group_name='ORA$AT_WGRP_OS';
       WINDOW_GROUP_NAME    WINDOW_NAME
1 ORA$AT_WGRP_OS MONDAY_WINDOW
2 ORA$AT_WGRP_OS TUESDAY_WINDOW
3 ORA$AT_WGRP_OS WEDNESDAY_WINDOW
4 ORA$AT_WGRP_OS THURSDAY_WINDOW
5 ORA$AT_WGRP_OS FRIDAY_WINDOW
6 ORA$AT_WGRP_OS SATURDAY_WINDOW
7 ORA$AT_WGRP_OS SUNDAY_WINDOW

查看子时间窗口信息

select a.window_name,a.next_start_date,a.active from dba_scheduler_windows a
inner join dba_scheduler_wingroup_members b on a.window_name = b.window_name
where b.window_group_name='ORA$AT_WGRP_OS';
       WINDOW_NAME    NEXT_START_DATE    ACTIVE
1 MONDAY_WINDOW 11-AUG-14 10.00.00.000000 PM +08:00 FALSE
2 TUESDAY_WINDOW 12-AUG-14 10.00.00.000000 PM +08:00 FALSE
3 WEDNESDAY_WINDOW 13-AUG-14 10.00.00.000000 PM +08:00 FALSE
4 THURSDAY_WINDOW 07-AUG-14 10.00.00.000000 PM +08:00 FALSE
5 FRIDAY_WINDOW 08-AUG-14 10.00.00.000000 PM +08:00 FALSE
6 SATURDAY_WINDOW 09-AUG-14 06.00.00.000000 AM +08:00 FALSE
7 SUNDAY_WINDOW 10-AUG-14 06.00.00.000000 AM +08:00 FALSE

通过这个查询可以看出DBA_AUTOTASK_WINDOW_CLIENTS视图的信息其实和上面的结果一样。

总结一下统计信息自动收集任务运行的步骤:
首先是dba_autotask_task-->dba_autotask_client建立自动执行任务
再根据时间窗口及资源组建立自动执行作业
dba_autotask_client-->dba_scheduler_window_groups-->dba_scheduler_windows-->dba_scheduler_jobs
dba_autotask_client-->dba_scheduler_job_classes
相关视图:
dba_autotask_task
dba_autotask_client
dba_autotask_client_job
dba_autotask_window_clients
dba_autotask_client_history

dba_scheduler_jobs
dba_scheduler_job_classes
dba_scheduler_window_groups
dba_scheduler_windows
dba_scheduler_wingroup_members

自定义自动收集任务时间窗口:
How to use an own Maintenance Window for the Statistics Collection in 11g [ID 1300313.1]

MOS相关文档: FAQ: Automatic Statistics Collection [ID 1233203.1]

Oracle11g 统计信息——统计信息自动收集任务的更多相关文章

  1. 11g统计信息自动收集任务

    1.查看统计信息自动收集任务的开启情况. select client_name,status from dba_autotask_client; 2.查看自动收集任务各个窗口的开启情况. col op ...

  2. OCM_第十三天课程:Section6 —》数据库性能调优 _结果缓存 /多列数据信息采集统计/采集数据信息保持游标有效

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  3. Hexo博客添加SEO-评论系统-阅读统计-站长统计

    原文地址:→传送门 写在前面 在五月出捣腾了一把个人博客,但是刚开始只做了一些基础设置,套路也没摸清,基础安装篇请看hexo从零开始到搭建完整,里面讲到了基础工具的安装及blog项目的文件夹含义,以及 ...

  4. redis的服务器信息状态信息查看

    Redis的服务器信息状态信息查看 Redis的提供了一个信息命令查看Redis的服务器的信息,类似的Linux提供一个顶级命令查看系统的信息 redis-cli info # Server #服务器 ...

  5. 重新想象 Windows 8 Store Apps (30) - 信息: 获取包信息, 系统信息, 硬件信息, PnP信息, 常用设备信息

    原文:重新想象 Windows 8 Store Apps (30) - 信息: 获取包信息, 系统信息, 硬件信息, PnP信息, 常用设备信息 [源码下载] 重新想象 Windows 8 Store ...

  6. 智能ERP收银统计-优惠统计计算规则

    1.报表统计->收银统计->优惠统计规则          第三方平台优惠:(堂食订单:支付宝口碑券优惠)+(外卖订单:商家承担优惠)          自平台优惠:(堂食订单:商家后台优 ...

  7. AFNetworking 打印错误信息(二进制信息)

    AFNetworking 打印错误信息(二进制信息) NSError *underError = error.userInfo[@"NSUnderlyingError"]; NSD ...

  8. 解决oracle11g安装导致数据库无法自动搜集统计信息-转

    近期发现个别11G数据库无法自动收集统计信息,部分视图查询结果如下: SQL> select client_name,status from dba_autotask_client where ...

  9. python 统计MySQL表信息

    一.场景描述 线上有一台MySQL服务器,里面有几十个数据库,每个库有N多表. 现在需要将每个表的信息,统计到excel中,格式如下: 库名 表名 表说明 建表语句 db1 users 用户表 CRE ...

随机推荐

  1. Windows Azure Virtual Network (11) 创建VNet-to-VNet的连接

    <Windows Azure Platform 系列文章目录> 我们知道,Azure Virtual Network可以 1.将对台Azure VM加入到同一个网段里,同时绑定内网IP地址 ...

  2. Linux安装配置tomcat

    1.首先配置好jdk 查看java版本:java -verson 1.官网下载jdk 2.tar -zxvf xxxx.tar.gz   解压 3.配置环境变量 <1># vi /etc/ ...

  3. ECharts整合HT for Web的网络拓扑图应用

    ECharts图形组件在1.0发布的时候我就已经有所关注,今天在做项目的时候遇到了图标的需求,在HT for Web上也有图形组件的功能,但是在尝试了下具体实现后,发现HT for Web的图形组件是 ...

  4. HTML5 Web 客户端五种离线存储方式汇总

    最近折腾HTML5游戏需要离线存储功能,便把目前可用的几种HTML5存储方式研究了下,基于HT for Web写了个综合的实例,分别利用了Cookie.WebStorage.IndexedDB以及Fi ...

  5. Git学习笔记(四)

    一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们 ...

  6. [译]学习IPython进行交互式计算和数据可视化(五)

    第四章:交互式绘图接口 本章我们将展示Python的绘图功能以及如何在IPython中交互式地使用它们. NumPy为处理大量的多维数组结构的数据提供了高效的方法.但是看行行列列的数字总不如直接看曲线 ...

  7. C#串口通信

    通过COM1发送数据,COM2接收数据.当COM2接收完本次发送的数据后,向COM1发送信息通知COM1本次数据已发完,COM1接到通知后,再发下一段数据.这样可以确保每次发送的数据都可以被正确接收. ...

  8. Java泛型-类型擦除

    一.概述 Java泛型在使用过程有诸多的问题,如不存在List<String>.class, List<Integer>不能赋值给List<Number>(不可协变 ...

  9. c#单例模式的实现

    单例模式定义:一个类有且仅有一个实例,并且自行实例化向整个系统提供. 实现要点: 1.是单例模式的类只提供私有的构造函数.   2.是类定义中含有一个该类的静态私有对象. 3.是该类提供了一个静态的共 ...

  10. iOS阶段学习第31天笔记(UINavigationBar介绍)

    iOS学习(UI)知识点整理 一.UINavigationBar 的介绍 1)概念:UINavigationBar 是用于定义导航栏按钮的一个类对象 2)在使用UINavigationBar之前必须先 ...