как запросить SSISDB, чтобы узнать об ошибках в пакетах?


15

Я видел этот вопрос SSIS 2012 - Как запросить запущенные в настоящее время пакеты в T-SQL?

Это дает мне следующий скрипт:

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;

Но это не отвечает на мои поиски. Я изучаю причины сбоя пакетов, и мне нужно получить сообщения об ошибках.

Где я могу найти его?

Я хотел бы использовать T-SQL для запроса сообщения об ошибке.

У меня также есть сценарий ниже, который приближает меня, но не совсем:

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

Это письмо, которое я хотел бы рассмотреть, как они получили это сообщение об ошибке:

Любая информация о том, как устранять ошибки служб SSIS, приветствуется.

введите описание изображения здесь

Ответы:


22

У меня есть несколько запросов, которые я использую. Общие понятия таковы, что таблица с информацией - это catalog.operation_messagesи вас интересуют события с типом 120 (ошибка).

В зависимости от того, насколько надежен запрос, который вы хотите построить, могут также представлять интерес следующие две производные таблицы.

--- 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);

Я использую подобные запросы, чтобы найти информацию об ошибках. Может быть, я забочусь только о том, какие были ошибки (запрос 1). В других случаях я хочу знать все действия всех операций, которые не удалось (запрос 2). Как правило, я ленивый и хочу увидеть всю информацию о последней неудачной операции (запрос 3 и обратите внимание на предостережение).

-- 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
    );

Возможно, я ленивый и не хочу искать эту информацию в случае неудачи, как, похоже, сделала ваша команда. У меня есть задание агента SQL, которое выполняется по требованию, и у меня есть задания, в которых выполняются пакеты служб SSIS, настроенные на выполнение этого задания в случае сбоя.

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;

Отрегулируйте, как вам нравится


8

Ты можешь использовать:

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

Это даст вам только сообщения об ошибках при выполнении пакетов служб SSIS.


1
Сделай этоMSG.message_type IN (120, 130)
AmDB

1
@AmDB: Вопрос об ошибках, а не предупреждениях. Если вы тоже хотите предупреждения, можно добавить message_type 130 тоже.
Питер Эльзинга

4

Вот один запрос, который я создал, чтобы найти сообщение об ошибке задания от 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 

Для подробного объяснения, пожалуйста: как запросить SSISDB, чтобы выяснить ошибки в пакетах?


1

Если вы действительно хотите знать, почему он не работает, вот несколько вещей, которые нужно проверить с пакетом и как устранить неполадки, чтобы убедиться, что это не проблема подключения или аутентификации.

Посмотрите на то, script taskчто появляется перед FTP taskи измените свойства для FTP-соединения. Это должно включать FTP server URL (or IP address), TCP port numberFTP-сервер прослушивает, usernameи и password.

Убедитесь, что все атрибуты FTP в этих свойствах строки подключения установлены правильно, и выполните тестирование из командной строки или из инструмента клиента FTP, чтобы убедиться, что все, что у вас есть, также разрешает подключение через этот метод, чтобы убедиться, что это не пароль или проблема с неверным значением о том, что вы подключаетесь к.


В этом вопросе не упоминается сценарий или задача FTP.
Nick.McDermaid

@ Nick.McDermaid Э-э ... на самом деле это конкретно показано в самом нижнем снимке экрана с вопросом, если вы посмотрите его полностью, вы тоже это увидите. Похоже, письмо, которое он получил, указывало на причину сбоя задания из-за проблемы с FTP. В следующий раз, когда вы решите отказаться от голосования, основываясь на своих заблуждениях, убедитесь, что вы полностью прочитали вопрос целиком и его содержание, прежде чем приступить к изучению содержания людей.
Сок Pimp IT

LOL это было довольно ненужным. Вы правы, он упоминает FTP в скриншоте в конце. Но скриншот выглядит как пример электронной почты для меня. Если перечитать вопрос, речь идет не о решении проблемы с FTP. Речь идет о поиске в журнале служб SSIS и отправке электронных писем. Там определенно ничего не говорится о «задаче сценария, которая появляется непосредственно перед задачей FTP». С моей точки зрения, реальный вопрос здесь о регистрации и оповещениях.
Nick.McDermaid

@ Nick.McDermaid Для меня снимок экрана электронной почты выглядел так, как будто кто-то уже сузил его до связи с проблемой аутентификации FTP, даже если это функция FTP, используемая в задании SSIS с соответствующим использованием протокола FTP. Я просто говорил, чтобы устранить проблему с аутентификацией FTP, просто подтвердите, что информация об учетных данных FTP в задании SSIS работает с другим методом подключения FTP вне задания SSIS, чтобы гарантировать, что имя пользователя и пароль, которые вы используете, например, не разрешают доступ.
Сок Pimp IT

Ха, " как пример электронной почты " .... серьезно, вы комик .... это движущий фактор всего вопроса. Я думаю, что вы не правы, и это просто так !! Я пытался помочь легко устранить неполадки 101 проблема аутентификации FTP через процесс устранения. Может быть, слишком простой и стандартный, но, согласно моей интерпретации и метке времени на ответе новичка, который я предоставил, это было настолько забавно, насколько это возможно. Если я не прав, круто; по крайней мере, я могу признать и учиться на этом. LOL
Сок Pimp IT
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.