[20180403]访问dba_autotask_task无输出问题.txt

--//链接http://www.itpub.net/thread-1911421-1-1.html的讨论,还没注意原先的帖子是2015年.
--//如果查询select task_name,client_name,status,CURRENT_JOB_NAME from dba_autotask_task ;没有输出,
--//一定是基表SYS.KET$_CLIENT_TASKS 没有记录.
--//通过测试发现一些以前没有注意的问题.

1.环境:
[email protected]> @ &r/ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

[email protected]> select count(*) from SYS.KET$_CLIENT_TASKS ;
  COUNT(*)
----------
         3

[email protected]> select task_name,client_name,status,CURRENT_JOB_NAME from dba_autotask_task ;
TASK_NAME               CLIENT_NAME                     STATUS   CURRENT_JOB_NAME
----------------------- ------------------------------- -------- -----------------
AUTO_SQL_TUNING_PROG    sql tuning advisor              ENABLED
auto_space_advisor_prog auto space advisor              ENABLED
gather_stats_prog       auto optimizer stats collection ENABLED

2.测试删除基表KET$_CLIENT_TASKS内容.
--//先做一个备份.千万不要在生产系统做这样的测试:
[email protected]> create table tt as select * from  KET$_CLIENT_TASKS;
Table created.

[email protected]> delete from KET$_CLIENT_TASKS;
3 rows deleted.

[email protected]> commit ;
Commit complete.

[email protected]> select task_name,client_name,status,CURRENT_JOB_NAME from dba_autotask_task;
no rows selected

--//可以发现现在没有输出了.
[email protected]> insert into SYS.KET$_CLIENT_TASKS select * from tt;
3 rows created.

[email protected]> commit ;
Commit complete.

[email protected]> select task_name,client_name,status,CURRENT_JOB_NAME from dba_autotask_task;
TASK_NAME               CLIENT_NAME                     STATUS   CURRENT_JOB_NAME
----------------------- ------------------------------- -------- ----------------
AUTO_SQL_TUNING_PROG    sql tuning advisor              ENABLED
auto_space_advisor_prog auto space advisor              ENABLED
gather_stats_prog       auto optimizer stats collection ENABLED

3.难道是人为删除吗?为了重复测试,我使用原来的冷备份覆盖了数据库.
--//发现重启数据库后发现:
[email protected]> select count(*) from SYS.KET$_CLIENT_TASKS ;
  COUNT(*)
----------
         0

--//再现了作者的问题.我本来想通过logminer发现问题,因为没有打开附加日志居然看不到对SYS.KET$_CLIENT_TASKS的删除操作.
--//不过经过一个"漫长"的分析,我发现设置参数job_queue_processes=0,使用冷备份再次启动,SYS.KET$_CLIENT_TASKS的信息不会删除.
--//也就是某个job或者scheduler,删除了SYS.KET$_CLIENT_TASKS的信息.

--//我看了数据库,发现job_name=‘ORA$AUTOTASK_CLEAN‘可能性最大,其执行脚本如下;

BEGIN
  SYS.DBMS_SCHEDULER.CREATE_JOB
    (
       job_name        => ‘SYS.ORA$AUTOTASK_CLEAN‘
      ,schedule_name   => ‘SYS.DAILY_PURGE_SCHEDULE‘
      ,program_name    => ‘SYS.ORA$AGE_AUTOTASK_DATA‘
      ,comments        => ‘Delete obsolete AUTOTASK repository data‘
    );
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘RESTARTABLE‘
     ,value     => FALSE);
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘LOGGING_LEVEL‘
     ,value     => SYS.DBMS_SCHEDULER.LOGGING_OFF);
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE_NULL
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘MAX_FAILURES‘);
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE_NULL
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘MAX_RUNS‘);
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘STOP_ON_WINDOW_CLOSE‘
     ,value     => FALSE);
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘JOB_PRIORITY‘
     ,value     => 3);
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE_NULL
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘SCHEDULE_LIMIT‘);
  SYS.DBMS_SCHEDULER.SET_ATTRIBUTE
    ( name      => ‘SYS.ORA$AUTOTASK_CLEAN‘
     ,attribute => ‘AUTO_DROP‘
     ,value     => FALSE);

SYS.DBMS_SCHEDULER.ENABLE
    (name                  => ‘SYS.ORA$AUTOTASK_CLEAN‘);
END;
/

--//可以确定调用程序是program_name    => ‘SYS.ORA$AGE_AUTOTASK_DATA‘.看看SYS.ORA$AGE_AUTOTASK_DATA执行内容:

BEGIN
  SYS.DBMS_SCHEDULER.CREATE_PROGRAM
    (
      program_name         => ‘SYS.ORA$AGE_AUTOTASK_DATA‘
     ,program_type         => ‘STORED_PROCEDURE‘
     ,program_action       => ‘dbms_autotask_prvt.age‘
     ,number_of_arguments  => 0
     ,enabled              => FALSE
     ,comments             => ‘deletes obsolete AUTOTASK repository data‘
    );

SYS.DBMS_SCHEDULER.ENABLE
    (name                  => ‘SYS.ORA$AGE_AUTOTASK_DATA‘);
END;
/

--//也就是手工执行dbms_autotask_prvt.age会清除SYS.KET$_CLIENT_TASKS ;看看是否正确.

@ &r/10046on 12
exec dbms_autotask_prvt.age;
@ &r/10046off

--//检查跟踪文件可以发现:
=====================
PARSING IN CURSOR #140216792384000 len=86 dep=1 uid=0 oct=7 lid=0 tim=1522658288077950 hv=4100613328 ad=‘7bedf198‘ sqlid=‘df4jnq7u6nt6h‘
DELETE FROM KET$_CLIENT_TASKS WHERE CURR_WIN_START < (SYSTIMESTAMP- INTERVAL ‘31‘ DAY)
END OF STMT
PARSE #140216792384000:c=25996,e=26168,p=0,cr=206,cu=0,mis=1,r=0,dep=1,og=1,plh=690981981,tim=1522658288077949
EXEC #140216792384000:c=0,e=109,p=0,cr=6,cu=0,mis=0,r=0,dep=1,og=1,plh=690981981,tim=1522658288078164
STAT #140216792384000 id=1 cnt=0 pid=0 pos=1 obj=0 op=‘DELETE  KET$_CLIENT_TASKS (cr=6 pr=0 pw=0 time=55 us)‘
STAT #140216792384000 id=2 cnt=0 pid=1 pos=1 obj=6275 op=‘TABLE ACCESS FULL KET$_CLIENT_TASKS (cr=6 pr=0 pw=0 time=49 us cost=3 size=35 card=1)‘
CLOSE #140216792384000:c=0,e=2,dep=1,type=3,tim=1522658288078288
=====================

--//可以发现启动调用job_name=‘ORA$AUTOTASK_CLEAN‘.但是删除有条件的WHERE CURR_WIN_START < (SYSTIMESTAMP- INTERVAL ‘31‘ DAY).
--//这样也验证我使用冷备份启动后为什么KET$_CLIENT_TASKS没有信息,信息已经删除了.

4.继续分析:
BEGIN
  DBMS_AUTO_TASK_ADMIN.disable(
    client_name => ‘auto space advisor‘,
    operation   => NULL,
    window_name => NULL);
END;
/

[email protected]> select task_name,client_name,status,CURRENT_JOB_NAME from dba_autotask_task;
no rows selected

--//居然还是没有信息插入基表KET$_CLIENT_TASKS .我仔细跟踪DBMS_AUTO_TASK_ADMIN.disable,发现实际修改的基表是:

[email protected]> select CLIENT_ID, OPERATION_ID, STATUS ,ATTRIBUTES, PRIORITY_OVERRIDE from KET$_CLIENT_config;
 CLIENT_ID OPERATION_ID     STATUS ATTRIBUTES PRIORITY_OVERRIDE
---------- ------------ ---------- ---------- -----------------
         0            0          2          0                 0
         4            0          2          5                 0
         5            0          1          5                 0
         6            0          2          5                 0
         1            0          2          1                 0
         2            0          2         20                 0
         3            0          2         34                 0
7 rows selected.
--//CLIENT_ID=5,STATUS=1表示disable.这时我才发现我查询错误的视图,实际上是查询:
[email protected]> column ATTRIBUTES format a56
[email protected]> select client_name, status,attributes,window_group from dba_autotask_client;
CLIENT_NAME                     STATUS   ATTRIBUTES                                               WINDOW_GROUP
------------------------------- -------- -------------------------------------------------------- ---------------
auto optimizer stats collection ENABLED  ON BY DEFAULT, VOLATILE, SAFE TO KILL                    ORA$AT_WGRP_OS
auto space advisor              DISABLED ON BY DEFAULT, VOLATILE, SAFE TO KILL                    ORA$AT_WGRP_SA
sql tuning advisor              ENABLED  ONCE PER WINDOW, ON BY DEFAULT, VOLATILE, SAFE TO KILL   ORA$AT_WGRP_SQ

--//oracle在2个视图DBA_AUTOTASK_TASK,DBA_AUTOTASK_CLIENT上非常容易混淆.
--//最后,贴一下oracle官网对这2个表的解释:

DBA_AUTOTASK_TASK:displays information about current and past automated maintenance tasks.
DBA_AUTOTASK_CLIENT:displays statistical data for each automated maintenance task over 7-day and 30-day periods.

--//至于dba_autotask_task等晚上10点scheduler运行就会有记录了.
--//第二天:

[email protected]> select count(*) from SYS.KET$_CLIENT_TASKS ;
  COUNT(*)
----------
         3

[email protected]> select task_name,client_name,status,CURRENT_JOB_NAME,LAST_GOOD_DATE from dba_autotask_task ;
TASK_NAME               CLIENT_NAME                     STATUS   CURRENT_JOB_NAME LAST_GOOD_DATE
----------------------- ------------------------------- -------- ---------------- ---------------------------------
AUTO_SQL_TUNING_PROG    sql tuning advisor              ENABLED                   2018-04-02 22:00:05.625135 +08:00
auto_space_advisor_prog auto space advisor              ENABLED                   2018-04-02 22:00:06.527905 +08:00
gather_stats_prog       auto optimizer stats collection ENABLED                   2018-04-02 22:00:17.128253 +08:00

--//总之这2个视图DBA_AUTOTASK_TASK,DBA_AUTOTASK_CLIENT非常容易混淆.

原文地址:https://www.cnblogs.com/lfree/p/8706330.html

时间: 2024-11-02 14:12:42

[20180403]访问dba_autotask_task无输出问题.txt的相关文章

adb logcat 通过包名过滤日志并输出到txt文件

最近学使用ADB命令抓包APP闪退的日志: 1)在cmd命令行中可以使用adb logcat 命令查看android系统的log,也可以使用adb shell进入到adb shell专用命令行 2)dos窗口可以直接输入log,或定向输出到txt文件: 3)按ctrl+c中断输入log记录: android输出的每一条日志都有一个标记和优先级与其关联. 优先级是下面的字符,顺序是从低到高: V - 明细 verbose(最低优先级) D - 调试 debug I - 信息 info W - 警告

将控制台输入的每一行字符串,输出至txt文件当中

/** *    需求:将控制台输入的每一行字符串,输出至txt文件当中. /** * 需求:将控制台输入的每一行字符串,输出至txt文件当中. * 思路: * 1.首先想到BufferReader高级流读取一行字符串readLine方法. * 2.但是前提依赖于字符转换流ISR和低级节点流,这里是从控制台输入,节点流自然是System.in.如果是从文件输入,则节点流换成FIS即可 * 3.这样就能建立一条输入流了.BufferedReader(new InputStreamReader(Sy

matlab————矩阵输出到txt

matlab如何输出矩阵到txt并指定数的精度 (2013-11-20 16:50:43)转载▼ 标签: matlab 输出数据 假设你的数据矩阵为a; [m n] = size(a); [filename pathname] = uiputfile{'*.txt','Select Save file'); if ~filename return; else str = [pathname filename]; fin = fopen(str,'wt'); for i = 1:m for j =

python筛选特定文件的信息按照格式输出到txt

最近搞数据库,为了把图片文件的信息导入数据库表中,我开始研究python列出图片文件,其中发现因为IE临时文件里有非常多的不需要的图片,就需要筛选掉一些文件. 最终用python输出了所有需要的图片文件的路径.文件名.时间到一个txt 1 import os 2 import time 3 4 def IsObjfile( path , filename , suffix , shield ): 5 #判断文件是否以suffix中的串结尾以及是否有不需要的文件路径 6 flag1 = False

解决sublime text运行javascript console无输出问题

1.使用nodeJS在sublime text 运行javascript 下载安装nodeJS 在sublime text新建build system:tools->build system->new build system-,输入代码: {  "cmd": ["node", "$file"],  "selector": "source.js"} 保存为一个新文件,任意命名,eg:node.

电信SDK Pay函数里面System.out.print 无输出消息

private void Pay(HashMap<String, String> payParams){ System.out.print("----------Pay DianXin----------"); // 勿使用 这个函数进行调试 输出不了消息. UnityPlayer.UnitySendMessage(m_GameObject,"Message","Pay DianXin......"); EgamePay.pay(m_

将矩阵输出到txt文件

将矩阵输出到txt文件中的方法,遍寻网络,始见真经!!! fid=fopen('C:Documents and Settingscleantotal.ped','wt');%写入文件路径 matrix=input_mattrix                        %input_matrix为待输出矩阵        [m,n]=size(matrix);       for i=1:1:m          for j=1:1:n             if j==n       

SLF4J 日志,catalina.out无输出问题解决

在部署完成项目之后,遇到了使用SLF4J输出,但是catalina.out无输出的问题, 查找错误文件后,找到了这样一行错误 Failed to load class "org.slf4j.impl.StaticLoggerBinder" 少包了,所以找到这个包 <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId

无线压力传感器信号不稳定、接电无输出问题分析

无线压力传感器是一款电池供电.具有无线通讯功能的高精度智能压力测量仪器.可广泛用于石油.化工.电力.冶金.制药.食品等工业领域,是传统压力表及传统压力传感器的理想升级换代产品,是工业自动化领域理想的压力测量仪表. 无线压力传感器的长久使用,指不定会碰到各种小问题,例如输出信号不稳定.接电无输出等问题. 无线压力传感器输出信号不稳定 (1)压力传感器输出信号不稳 ????? 故障检查.分析:输出信号不稳的原因有以下几种: ①压力源本身是一个不稳定的压力; ②仪表或压力传感器抗干扰能力不强; ③传感