1

我们有很多通过 Control-M 中的 .bat(batch) 文件运行的 SSIS 包。我们遇到的问题是,如果 SSIS 包失败,批处理文件(通过 Control-M 作业执行)永远不会显示真正的 SSIS 错误消息,生产支持团队希望在批处理文件输出日志中看到这些错误,得到显示在 control-m 中,而不是单独进入 SSIS 错误报告。

所以例如批处理文件错误输出是(当前输出)

IS 服务器上的包执行失败。执行 ID:118475,执行状态:4。要查看执行的详细信息,请右键单击集成服务目录,然后打开 [All Executions] 报告

但 SSIS 中的真正错误是(预期输出将附加到当前输出)

ExtractConform_Master:错误:SSIS 错误代码 DTS_E_OLEDBERROR。发生 OLE DB 错误。错误代码:0x80004005。OLE DB 记录可用。来源:“Microsoft SQL Server Native Client 11.0”Hresult:0x80004005 描述:“用户 'UK\blah' 登录失败。”。OLE DB 记录可用。来源:“Microsoft SQL Server Native Client 11.0” Hresult:0x80004005 描述:“无法打开登录请求的数据库“Blah”。登录失败。”。

当前示例批处理文件如下所示“

echo off

set PackageName=Publish.dtsx
set EnvironmentName=BlahEnvironment
set BasePath=%~dp0..

REM Parameters
REM ====================================================

set Cluster=Clustername
set Subcluster=SubclusterName
set QueueName=QueueName



"%DTExecFilePath%" /ISSERVER     "\%SSISCatalog%\%FolderName%\%ProjectName%\%PackageName%" /SERVER %SSISSERVER% /Envreference %env% /Par "$ServerOption::SYNCHRONIZED(Boolean)";True /Par "Cluster";%Cluster% /Par "Subcluster";%Subcluster% /Par "$Package::QueueName";%QueueName%

echo ERROR LEVEL is %ERRORLEVEL%

IF %ERRORLEVEL% GEQ 1 EXIT /b 1
IF %ERRORLEVEL% EQU 0 EXIT /b 0 code here

有什么建议吗?

4

1 回答 1

1

我建议您使用Control-M for Database模块从 SSIS SQL Server 运行 DTSX。这将允许您使用数据库作业类型,您可以在其中启用附加DTSX 执行输出的选项。

于 2018-10-25T01:23:57.353 回答