天天看點

Oracle 12c中JOB運作失敗的簡單處理(r11筆記第66天)

在之前簡單分析過一個12c中資料字典的小問題。

Oracle 12c資料字典的小問題(r11筆記第49天)

最近檢視郵件,12c的一個PDB還是存在JOB運作異常的情況,因為是測試環境,不是業務類的JOB,這個問題就給了我一些時間來修複。

首先因為資料字典cdb_scheduler_job_run_details的問題,還不能一下子就查出資料。我們分階段來完成這個工作,即分成幾條SQL語句來查。

首先檢視PDB中的JOB執行情況。可以看到con_id=8的PDB存在失敗的JOB

SQL> select con_id,status,count(*)from cdb_SCHEDULER_JOB_RUN_DETAILS group by con_id,status;

    CON_ID STATUS                           COUNT(*)

---------- ------------------------------ ----------

         1 SUCCEEDED                           13448

         1 STOPPED                                 1

         8 FAILED                                 93

         8 SUCCEEDED                            5048

         3 SUCCEEDED                           13109  

看起來失敗的還不少,當然這種方式得到的是一個整體的情況,我們需要過濾得到近些天來的執行情況。

SQL> select con_id,status,count(*)from cdb_SCHEDULER_JOB_RUN_DETAILS where log_date>sysdate-20 group by con_id,status;

         8 FAILED                                 19

         8 SUCCEEDED                             161

         6 SUCCEEDED                            8290

...        我們切換到這個容器 con_id=8

alter session set container=actvdb;

下面的語句很普通,但是在這種方式下執行就是通不過。

SQL> SELECT JOB_NAME,LOG_DATE,count(*)from

DBA_SCHEDULER_JOB_RUN_DETAILS where log_date>sysdate-20 and

status='FAILED' group by job_name,LOG_DATE;

SELECT

JOB_NAME,LOG_DATE,count(*)from DBA_SCHEDULER_JOB_RUN_DETAILS where

log_date>sysdate-20 and status='FAILED' group by job_name,LOG_DATE

                                      *

ERROR at line 1:

ORA-03115: unsupported network datatype or representation一種解決方式就是直接使用PDB的DBA賬号。繼續檢視就沒有問題了。

status='FAILED' group by job_name,LOG_DATE

JOB_NAME                 LOG_DATE                                   COUNT(*)

------------------------ ---------------------------------------- ----------

ORA$AT_SA_SPC_SY_6447    15-JAN-17 06.00.26.399954 AM +08:00               1

ORA$AT_SA_SPC_SY_6467    16-JAN-17 10.00.22.607829 PM +08:00               1

ORA$AT_SA_SPC_SY_6470    17-JAN-17 10.00.19.712548 PM +08:00               1

ORA$AT_SA_SPC_SY_6473    18-JAN-17 10.00.15.807239 PM +08:00               1

ORA$AT_SA_SPC_SY_6476    19-JAN-17 10.00.16.822079 PM +08:00               1

ORA$AT_SA_SPC_SY_6479    20-JAN-17 10.00.18.105956 PM +08:00               1

ORA$AT_SA_SPC_SY_6482    21-JAN-17 06.00.15.902576 AM +08:00               1

ORA$AT_SA_SPC_SY_6487    22-JAN-17 06.00.30.243598 AM +08:00               1

ORA$AT_SA_SPC_SY_6490    23-JAN-17 10.00.13.396406 PM +08:00               1當然我們看到了不少生疏的字眼。這些JOB一看就不是業務層面的。

這類JOB執行為什麼失敗呢。可以檢視trace檔案。

ORA-12012: error on auto execute of job "SYS"."ORA$AT_SA_SPC_SY_6539"

ORA-13613: The requested operation is not supported for this advisor object.

ORA-06512: at "SYS.PRVT_ADVISOR", line 5018

ORA-06512: at "SYS.DBMS_ADVISOR", line 103

ORA-06512: at "SYS.DBMS_SPACE", line 2486

ORA-06512: at "SYS.DBMS_SPACE", line 2643總體來看這個JOB是系統層面的,怎麼了解呢。

Oracle自動運作的JOB有如下幾個:

SQL> select * from DBA_AUTOTASK_WINDOW_CLIENTS

WINDOW_NAME       WINDOW_NEXT_TIME                    WINDO AUTOTASK OPTIMIZE SEGMENT_ SQL_TUNE HEALTH_M

----------------------------------------------------- ----- -------- -------- -------- -------- --------

MONDAY_WINDOW     06-FEB-17 10.00.00.000000 PM PRC    FALSE ENABLED  ENABLED  ENABLED  ENABLED  DISABLED

TUESDAY_WINDOW    07-FEB-17 10.00.00.000000 PM PRC    FALSE ENABLED  ENABLED  ENABLED  ENABLED  DISABLED

WEDNESDAY_WINDOW  08-FEB-17 10.00.00.000000 PM PRC    FALSE ENABLED  ENABLED  ENABLED  ENABLED  DISABLED

THURSDAY_WINDOW   09-FEB-17 10.00.00.000000 PM PRC    FALSE ENABLED  ENABLED  ENABLED  ENABLED  DISABLED

FRIDAY_WINDOW     03-FEB-17 10.00.00.000000 PM PRC    FALSE ENABLED  ENABLED  ENABLED  ENABLED  DISABLED

SATURDAY_WINDOW   04-FEB-17 06.00.00.000000 AM PRC    FALSE ENABLED  ENABLED  ENABLED  ENABLED  DISABLED

SUNDAY_WINDOW     05-FEB-17 06.00.00.000000 AM PRC    FALSE ENABLED  ENABLED  ENABLED  ENABLED  DISABLED可以看到是每天10點開始,周末略有差别。自動設定了特定的視窗時間。

大體有如下的三類自動任務。

SQL> select client_name,status from DBA_AUTOTASK_CLIENT;

CLIENT_NAME                         STATUS

--------------------------------------------

auto optimizer stats collection     ENABLED

auto space advisor                  ENABLED

sql tuning advisor                  ENABLED該怎麼了解這三類自動任務呢,還是有一定的規律可循。命名規則如下:

ORA$AT_SA_SPC_SY_nnn for Space advisor tasks

ORA$AT_OS_OPT_SY_nnn for Optimiser stats collection tasks

ORA$AT_SQ_SQL_SW_nnn for Space advisor tasks在MOS notes 756734.1, 755838.1, 466920.1 和Bug 12343947 都有詳細的解釋。

是以根據錯誤可以得出這個JOB是來自于Space advisor tasks。

因為這個PDB是直接遷移過來,做的模闆檔案的導入,不排除有一些相容性的問題,而這個自動任務也不是必須的。是以我們可以考慮禁用。

采用如下的方式禁用即可:

begin

DBMS_AUTO_TASK_ADMIN.DISABLE(client_name => 'auto space advisor',

operation => NULL,

window_name => NULL);

end;

/然後再次驗證即可,問題就這樣得到了一個初步的解決。