默认情况下,一切都将在服务器上以 64 位运行。要更改此行为,您需要指明应该使用 32 位版本的 dtexec。对于 2012 SSISDB,我们有两种简单的方法来调用我们的包:SQL 代理和catalog.start_execution 方法。
catalog.start_execution
对于单一服务包运行,您可以在 SSISDB 目录中找到该包并右键单击它们到Execute...
在弹出的对话框中,您需要转到高级选项卡并选中32-bit runtime 框。这将在每次运行包时完成。
在幕后,向导生成的 SQL 看起来像
DECLARE @execution_id bigint
EXEC [SSISDB].[catalog].[create_execution]
@package_name = N'Package.dtsx'
, @execution_id = @execution_id OUTPUT
, @folder_name = N'POC'
, @project_name = N'SSISConfigMixAndMatch'
, @use32bitruntime = True
, @reference_id = NULL
SELECT
@execution_id
DECLARE @var0 smallint = 1
EXEC [SSISDB].[catalog].[set_execution_parameter_value]
@execution_id
, @object_type = 50
, @parameter_name = N'LOGGING_LEVEL'
, @parameter_value = @var0
EXEC [SSISDB].[catalog].[start_execution]
@execution_id
GO
如您所见,@use32bitruntime 参数传递了一个 True 值,表示它应该在 32 个空间中运行。
SQL 代理
对于重复的包运行,我们通常使用调度工具。要在代理中设置包的 32 位设置,单击路径基本相同,只是您首先需要单击“配置”选项卡并然后单击“高级”选项卡以选择 32-bit runtime
作业步骤定义类似于
EXEC msdb.dbo.sp_add_jobstep
@job_name = N'Do it'
, @step_name = N'Run in 32bit'
, @step_id = 1
, @cmdexec_success_code = 0
, @on_success_action = 1
, @on_fail_action = 2
, @retry_attempts = 0
, @retry_interval = 0
, @os_run_priority = 0
, @subsystem = N'SSIS'
, @command = N'/ISSERVER "\"\SSISDB\POC\SSISConfigMixAndMatch\Package.dtsx\"" /SERVER "\".\dev2014\"" /X86 /Par "\"$ServerOption::LOGGING_LEVEL(Int16)\"";1 /Par "\"$ServerOption::SYNCHRONIZED(Boolean)\"";True /CALLERINFO SQLAGENT /REPORTING E'
, @database_name = N'master'
, @flags = 0
您会看到,在@command 调用中,向导会生成/X86 调用,这是为 SQL 代理保留的特殊参数(检查开头的 BOL 链接),以指示 32 位还是 64 位版本应该使用 dtexec。命令行调用将要求我们显式使用正确的 dtexec。默认情况下,64 位 dtexec 将首先列在您的 PATH 环境中
64 位 dtexec 位置
- C:\Program Files\Microsoft SQL Server\90\DTS\Binn\DTExec.exe
- C:\Program Files\Microsoft SQL Server\100\DTS\Binn\DTExec.exe
- C:\Program Files\Microsoft SQL Server\110\DTS\Binn\DTExec.exe
- C:\Program Files\Microsoft SQL Server\120\DTS\Binn\DTExec.exe
32 位 dtexec 位置
- C:\Program Files (x86)\Microsoft SQL Server\90\DTS\Binn\DTExec.exe
- C:\Program Files (x86)\Microsoft SQL Server\100\DTS\Binn\DTExec.exe
- C:\Program Files (x86)\Microsoft SQL Server\110\DTS\Binn\DTExec.exe
- C:\Program Files (x86)\Microsoft SQL Server\120\DTS\Binn\DTExec.exe
进一步的故障排除驱动程序
它在一台服务器上运行,不在另一台服务器上。
第 1 步 - 确认您已安装驱动程序。很傻,很明显,但是有很多问题,人们错误地认为部署 SSIS 包/.ispac 也会部署所有引用的程序集。这不是 nuget 所以不,所有的先决条件都需要安装,并正确安装(看到人们试图将程序集复制到 GAC 中而不是使用该工具)
第 2 步 - 验证跨服务器的驱动程序安装匹配。再一次,似乎很明显,但我经历过痛苦,通常是 VS_NEEDSNEWMETADATA,驱动程序版本 4.0.2.013 的点差产生了与 4.0.2.014 不同的结果
第 3 步 - 确保您定义的所有 DSN 都在正确的空间中定义。这个咬人的原因有很多。我认为直到 Server 2012 才可以通过在文件系统上找到 odbcad32.exe(与管理工具相关的可执行文件 -> 数据源 (ODBC) 相关的可执行文件)来获得 32 位版本。更令人困惑的是,可执行文件名为 odbcad32.exe,无论它是在 System32 还是 SysWOW64 中,这两个文件夹分别用于 64 位驱动程序和 32 位驱动程序。是的,未来的读者,这不是一个错字。 64位版本的应用在System32,32位的版本在SysWOW64。这是一个旨在尽量减少影响的设计决策。
在测试和正式服务器上,运行C:\Windows\SysWOW64\odbcad32.exe 找到您的 FoxPro 驱动程序和相关的 DSN,它们是否符合预期?
第 4 步 - 奇怪的权限检查。以“普通”帐户登录到两台服务器并从命令行运行包。重复此步骤,但使用代理执行它,使用您可能定义或未定义的任何代理。如果第一个有效但后者失败,这通常表明存在权限问题。可能是 SQL Server 或代理帐户无法访问驱动程序安装到的任何文件夹。可能是该帐户需要 InteractWithDesktop 权限或其他一些被拒绝或未明确授予的权限。