我们有很多通过 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
有什么建议吗?