come interrogare SSISDB per scoprire gli errori nei pacchetti?


15

Ho visto questa domanda SSIS 2012 - Come eseguire query sui pacchetti attualmente in esecuzione in T-SQL?

Mi dà il seguente script:

SELECT
    E.execution_id
,   E.folder_name
,   E.project_name
,   E.package_name
,   E.reference_id
,   E.reference_type
,   E.environment_folder_name
,   E.environment_name
,   E.project_lsn
,   E.executed_as_sid
,   E.executed_as_name
,   E.use32bitruntime
,   E.operation_type
,   E.created_time
,   E.object_type
,   E.object_id
,   E.status
,   E.start_time
,   E.end_time
,   E.caller_sid
,   E.caller_name
,   E.process_id
,   E.stopped_by_sid
,   E.stopped_by_name
,   E.dump_id
,   E.server_name
,   E.machine_name
,   E.total_physical_memory_kb
,   E.available_physical_memory_kb
,   E.total_page_file_kb
,   E.available_page_file_kb
,   E.cpu_count
,   F.folder_id
,   F.name
,   F.description
,   F.created_by_sid
,   F.created_by_name
,   F.created_time
,   P.project_id
,   P.folder_id
,   P.name
,   P.description
,   P.project_format_version
,   P.deployed_by_sid
,   P.deployed_by_name
,   P.last_deployed_time
,   P.created_time
,   P.object_version_lsn
,   P.validation_status
,   P.last_validation_time
,   PKG.package_id
,   PKG.name
,   PKG.package_guid
,   PKG.description
,   PKG.package_format_version
,   PKG.version_major
,   PKG.version_minor
,   PKG.version_build
,   PKG.version_comments
,   PKG.version_guid
,   PKG.project_id
,   PKG.entry_point
,   PKG.validation_status
,   PKG.last_validation_time
FROM
    SSISDB.catalog.executions AS E
INNER JOIN
    ssisdb.catalog.folders AS F ON F.name = E.folder_name
INNER JOIN 
    SSISDB.catalog.projects AS P ON P.folder_id = F.folder_id
                                 AND P.name = E.project_name
INNER JOIN
    SSISDB.catalog.packages AS PKG ON PKG.project_id = P.project_id
                                   AND PKG.name = E.package_name;

Ma non risponde alla mia ricerca. Sto studiando i motivi per cui i pacchetti falliscono e devo prendere i messaggi di errore.

Dove posso trovarlo?

Vorrei utilizzare T-SQL per eseguire una query per il messaggio di errore.

Ho anche questo script qui sotto, che mi porta vicino, ma non del tutto:

SELECT 
    q.*
FROM
    (SELECT em.*
     FROM SSISDB.catalog.event_messages em
     WHERE em.operation_id = (SELECT MAX(execution_id) 
                              FROM SSISDB.catalog.executions)
       AND event_name NOT LIKE '%Validate%') q
/* Put in whatever WHERE predicates you might like*/
--WHERE event_name = 'OnError'
WHERE package_name = 'InfoGroup Feed.dtsx'
--WHERE execution_path LIKE '%<some executable>%'
ORDER BY message_time DESC

Questa è l'e-mail che vorrei affrontare, come sono arrivati ​​a quel messaggio di errore:

Qualsiasi informazione su come risolvere errori SSIS è benvenuta.

inserisci qui la descrizione dell'immagine

Risposte:


22

Ho una manciata di domande che utilizzo. I concetti generali sono che la tabella con le informazioni ècatalog.operation_messages e tu sei interessato ad eventi con un tipo 120 (errore).

A seconda della robustezza di una query che si desidera creare, potrebbero essere interessanti anche le seguenti due tabelle derivate.

--- http://technet.microsoft.com/en-us/library/ff877994.aspx
-- This query translates the message_type from SSISDB.catalog.operation_messages
-- into useful text
SELECT
    D.message_type
,   D.message_desc
FROM
(
    VALUES
        (-1,'Unknown')
    ,   (120,'Error')
    ,   (110,'Warning')
    ,   (70,'Information')
    ,   (10,'Pre-validate')
    ,   (20,'Post-validate')
    ,   (30,'Pre-execute')
    ,   (40,'Post-execute')
    ,   (60,'Progress')
    ,   (50,'StatusChange')
    ,   (100,'QueryCancel')
    ,   (130,'TaskFailed')
    ,   (90,'Diagnostic')
    ,   (200,'Custom')
    ,   (140,'DiagnosticEx Whenever an Execute Package task executes a child package, it logs this event. The event message consists of the parameter values passed to child packages.  The value of the message column for DiagnosticEx is XML text.')
    ,   (400,'NonDiagnostic')
    ,   (80,'VariableValueChanged')
) D (message_type, message_desc);


-- Where was the error message generated?
SELECT
    D.message_source_type
,   D.message_source_desc
FROM
(
    VALUES
        (10,'Entry APIs, such as T-SQL and CLR Stored procedures')
    ,   (20,'External process used to run package (ISServerExec.exe)')
    ,   (30,'Package-level objects')
    ,   (40,'Control Flow tasks')
    ,   (50,'Control Flow containers')
    ,   (60,'Data Flow task')
) D (message_source_type, message_source_desc);

Uso query come questa per trovare informazioni sugli errori. Forse mi interessa solo quali fossero gli errori (query 1). Altre volte, voglio conoscere tutte le attività di tutte le operazioni non riuscite (query 2). In generale, sono pigro e voglio vedere tutte le informazioni sull'ultima operazione fallita (interroga 3 e nota l'avvertimento).

-- http://msdn.microsoft.com/en-us/library/ff877994.aspx
-- Find all error messages
SELECT
    OM.operation_message_id
,   OM.operation_id
,   OM.message_time
,   OM.message_type
,   OM.message_source_type
,   OM.message
,   OM.extended_info_id
FROM
    catalog.operation_messages AS OM
WHERE
    OM.message_type = 120;

-- Generate all the messages associated to failing operations
SELECT
    OM.operation_message_id
,   OM.operation_id
,   OM.message_time
,   OM.message_type
,   OM.message_source_type
,   OM.message
,   OM.extended_info_id
FROM
    catalog.operation_messages AS OM
    INNER JOIN
    (  
        -- Find failing operations
        SELECT DISTINCT
            OM.operation_id  
        FROM
            catalog.operation_messages AS OM
        WHERE
            OM.message_type = 120
    ) D
    ON D.operation_id = OM.operation_id;

-- Find all messages associated to the last failing run
SELECT
    OM.operation_message_id
,   OM.operation_id
,   OM.message_time
,   OM.message_type
,   OM.message_source_type
,   OM.message
,   OM.extended_info_id
FROM
    catalog.operation_messages AS OM
WHERE
    OM.operation_id = 
    (  
        -- Find the last failing operation
        -- lazy assumption that biggest operation
        -- id is last. Could be incorrect if a long
        -- running process fails after a quick process
        -- has also failed
        SELECT 
            MAX(OM.operation_id)
        FROM
            catalog.operation_messages AS OM
        WHERE
            OM.message_type = 120
    );

Forse sono pigro e non voglio andare a cercare queste informazioni in caso di fallimento, proprio come sembra aver fatto la tua squadra. Ho un lavoro di SQL Agent che viene eseguito su richiesta e ho lavori che eseguono pacchetti SSIS impostati per eseguire quel lavoro in caso di errore.

DECLARE
    @profile_name sysname = 'SQLAdmins'
,   @recipients varchar(max) = 'billinkc@kfc.com'
,   @copy_recipients varchar(max) = NULL
,   @blind_copy_recipients varchar(max) = NULL
,   @subject nvarchar(255) = 'failed package test'
,   @body nvarchar(max) = 'Stuff has failed, fix please'
,   @body_format varchar(20) = NULL
,   @importance varchar(6) = 'NORMAL'
,   @sensitivity varchar(12) = 'NORMAL'
,   @file_attachments nvarchar(max) = NULL
,   @query nvarchar(max) = N'
SELECT
    O.object_name AS FailingPackageName
,   O.object_id
,   O.caller_name
,   O.server_name
,   O.operation_id
,   OM.message_time
,   EM.message_desc
,   D.message_source_desc
,   OM.message
FROM
    SSISDB.catalog.operation_messages AS OM
    INNER JOIN
        SSISDB.catalog.operations AS O
        ON O.operation_id = OM.operation_id
    INNER JOIN
    (
        VALUES
            (-1,''Unknown'')
        ,   (120,''Error'')
        ,   (110,''Warning'')
        ,   (70,''Information'')
        ,   (10,''Pre-validate'')
        ,   (20,''Post-validate'')
        ,   (30,''Pre-execute'')
        ,   (40,''Post-execute'')
        ,   (60,''Progress'')
        ,   (50,''StatusChange'')
        ,   (100,''QueryCancel'')
        ,   (130,''TaskFailed'')
        ,   (90,''Diagnostic'')
        ,   (200,''Custom'')
        ,   (140,''DiagnosticEx Whenever an Execute Package task executes a child package, it logs this event. The event message consists of the parameter values passed to child packages.  The value of the message column for DiagnosticEx is XML text.'')
        ,   (400,''NonDiagnostic'')
        ,   (80,''VariableValueChanged'')
    ) EM (message_type, message_desc)
        ON EM.message_type = OM.message_type
    INNER JOIN
    (
        VALUES
            (10,''Entry APIs, such as T-SQL and CLR Stored procedures'')
        ,   (20,''External process used to run package (ISServerExec.exe)'')
        ,   (30,''Package-level objects'')
        ,   (40,''Control Flow tasks'')
        ,   (50,''Control Flow containers'')
        ,   (60,''Data Flow task'')
    ) D (message_source_type, message_source_desc)
        ON D.message_source_type = OM.message_source_type
WHERE
    OM.operation_id = 
    (  
        SELECT 
            MAX(OM.operation_id)
        FROM
            SSISDB.catalog.operation_messages AS OM
        WHERE
            OM.message_type = 120
    )
    AND OM.message_type IN (120, 130);
'
,   @execute_query_database sysname = NULL
,   @attach_query_result_as_file bit = 0
,   @query_attachment_filename nvarchar(260) = NULL
,   @query_result_header bit = 1
,   @query_result_width int = 256
,   @query_result_separator char(1) = char(13)
,   @exclude_query_output bit  = 0
,   @append_query_error bit = 0
,   @query_no_truncate bit = 0
,   @query_result_no_padding bit = 0
,   @mailitem_id int = NULL
,   @from_address varchar(max) = NULL
,   @reply_to varchar(max) = NULL;

-- Send email about the failure    
EXECUTE msdb.dbo.sp_send_dbmail
    @profile_name 
,   @recipients
,   @copy_recipients
,   @blind_copy_recipients
,   @subject
,   @body
,   @body_format
,   @importance
,   @sensitivity
,   @file_attachments
,   @query
,   @execute_query_database
,   @attach_query_result_as_file
,   @query_attachment_filename
,   @query_result_header
,   @query_result_width
,   @query_result_separator
,   @exclude_query_output
,   @append_query_error
,   @query_no_truncate
,   @query_result_no_padding
,   @mailitem_id OUTPUT
,   @from_address
,   @reply_to;

Regola come preferisci


8

Puoi usare:

SELECT      OPR.object_name
            , MSG.message_time
            , MSG.message
FROM        catalog.operation_messages  AS MSG
INNER JOIN  catalog.operations          AS OPR
    ON      OPR.operation_id            = MSG.operation_id
WHERE       MSG.message_type            = 120

Questo ti darà solo i messaggi di errore delle esecuzioni del pacchetto SSIS.


1
FalloMSG.message_type IN (120, 130)
AmDB,

1
@AmDB: la domanda riguarda errori, non avvisi. Se vuoi anche avvisi, puoi aggiungere anche message_type 130.
Peter Elzinga,

4

Ecco una query che ho creato per trovare il messaggio di errore del processo da SSISDB:

DECLARE @DATE DATE = GETDATE() - 7 -- This is to restrict the data for last 7 days, used in ON condition 

SELECT O.Operation_Id -- Not much of use 
,E.Folder_Name AS Project_Name 
,E.Project_name AS SSIS_Project_Name 
,EM.Package_Name 
,CONVERT(DATETIME, O.start_time) AS Start_Time 
,CONVERT(DATETIME, O.end_time) AS End_Time 
,OM.message as [Error_Message] 
,EM.Event_Name 
,EM.Message_Source_Name AS Component_Name 
,EM.Subcomponent_Name AS Sub_Component_Name 
,E.Environment_Name 
,CASE E.Use32BitRunTime 
WHEN 1 
THEN 'Yes' 
ELSE 'NO' 
END Use32BitRunTime 
,EM.Package_Path 
,E.Executed_as_name AS Executed_By 

FROM [SSISDB].[internal].[operations] AS O 
INNER JOIN [SSISDB].[internal].[event_messages] AS EM 
ON o.start_time >= @date -- Restrict data by date 
AND EM.operation_id = O.operation_id 

-- Edit: I change the alias from OMs to OM here:
INNER JOIN [SSISDB].[internal].[operation_messages] AS OM
ON EM.operation_id = OM.operation_id 

INNER JOIN [SSISDB].[internal].[executions] AS E 
ON OM.Operation_id = E.EXECUTION_ID 

WHERE OM.Message_Type = 120 -- 120 means Error 
AND EM.event_name = 'OnError' 
-- This is something i'm not sure right now but SSIS.Pipeline just adding duplicates so I'm removing it. 
AND ISNULL(EM.subcomponent_name, '') <> 'SSIS.Pipeline' 
ORDER BY EM.operation_id DESC 

Per la spiegazione dettagliata si prega di: come interrogare SSISDB per scoprire gli errori nei pacchetti?


1

Se vuoi davvero sapere perché non funziona, ecco alcune cose da verificare con il pacchetto e come risolvere i problemi per assicurarti che non si tratti di un problema di connessione o autenticazione.

Guarda quello script taskche appare poco prima di FTP taske modifica le proprietà per la connessione FTP. Ciò dovrebbe includere il FTP server URL (or IP address), il TCP port numberserver FTP ascolta, il username, e password.

Assicurati che tutti gli attributi FTP in queste proprietà della stringa di connessione siano impostati correttamente e esegui il test dalla riga di comando o da uno strumento client FTP per assicurarti che qualunque cosa tu abbia valore in questo caso consenta anche la connessione tramite quel metodo per assicurarti che non sia una password o un problema di valore errato di ciò a cui ti stai connettendo.


Non ci sono script o attività FTP menzionati nella domanda.
Nick.McDermaid

@ Nick.McDermaid Uh .... in realtà quello è mostrato nello specifico nella parte inferiore della schermata della domanda se lo guardi completamente lo vedrai. Sembra che l'e-mail che ha ricevuto indicava il motivo per cui il lavoro non riusciva era dovuto al problema FTP. La prossima volta che deciderai di votare un voto in base alle tue idee sbagliate, assicurati di leggere attentamente l'intera domanda e i suoi contenuti prima di iniziare a esaminare il contenuto delle persone.
Pimp Juice IT

LOL che era abbastanza inutile. Hai ragione, menziona FTP nello screenshot alla fine. Ma lo screenshot mi sembra solo un esempio di email. Se rileggi la domanda, non si tratta di risolvere un problema FTP. Si tratta di cercare nel registro SSIS e di inviare e-mail. Non c'è assolutamente nulla riguardo "all'attività di script che appare appena prima dell'attività FTP" lì. Dal mio punto di vista, la vera domanda qui riguarda la registrazione e gli avvisi.
Nick.McDermaid

@ Nick.McDermaid Per me la schermata della posta elettronica sembrava che qualcuno lo avesse già limitato per essere correlato a un problema di autenticazione FTP anche se si tratta della funzionalità FTP utilizzata in un lavoro SSIS che utilizza il protocollo FTP di conseguenza. Stavo solo dicendo di risolvere il problema di autenticazione FTP, semplicemente confermare che le informazioni sulle credenziali FTP all'interno di un lavoro SSIS funzionano con un altro metodo di connessione FTP al di fuori del lavoro SSIS per garantire che il nome utente e la password che si sta utilizzando, ad esempio, non consentano l'accesso.
Pimp Juice IT

Ah, " come un esempio di email " .... sul serio, sei un comico .... questo è il fattore trainante di tutta la domanda. Penso che tu abbia torto e che invece è proprio così !! Stavo cercando di aiutare a risolvere facilmente il problema di autenticazione FTP 101 tramite il processo di eliminazione. Forse troppo semplice e standard, ma secondo la mia interpretazione e il timestamp sulla risposta da principiante che ho fornito, questo è quello che era più divertente che potesse essere. Se sbaglio, fico; almeno posso ammetterlo e imparare da esso. LOL
Pimp Juice IT
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.