SSIS学习使用十四:项目转换概述和转换包部署模型为项目部署模型

这是我参与11月更文挑战的第21天,活动详情查看: 2021最后一次更文挑战

注:本部分主要介绍SSIS项目升级(升级至SSIS2012)。因此不重点详细操作每一步(个人演示从一开始就是使用的 SSIS 2012)。 但是关于项目部署模型的转换,可以详细了解下。

在本文中,将使用 SQL Server Data Tools —— 商业智能( SSDT-BI )或 Visual Studio 2012 将第一个 SSIS 项目转换为 SSIS2012 。可以在此处查看 SSIS 2012中的新特性 。如果想使用新的 SSIS 2012 目录( Catalog ),则项目必须遵循“项目部署模型”(将在本文中进行演示)。

使用 SSDT-BI 转换到 SSIS 2012

在本系列的第十三篇,SSIS变量概述中,我们从头创建了一个SSIS项目( My_Second_SSIS_Project )。首先,我们使用 SQL Server Data Tools–商业智能(SSDT-BI)将之前的名为 My_First_SSIS_Project 的SSIS项目转换为SSIS 2012。

至少有两种方法来进行SSIS项目转换:您可以从Windows资源管理器中通过 “打开方式”( Open With ) 菜单打开解决方案文件( *.sln ),也可以启动 SQL Server Data Tools– BI,然后从起始页上的 “打开项目” 链接中打开SSIS解决方案。在 SSIS变量概述 中,演示了如何从起始页创建新的SSIS项目,该过程与使用 “打开项目” 链接转换SSIS解决方案非常相似。此处使用 Windows资源管理器 进行演示。

下图显示了这种方法 —— 使用 Windows资源管理器 的 “打开方式” 菜单打开 Visual Studio解决方案文件 —— My_First_SSIS_Project.sln

我更喜欢启动 SSDT-BI,然后打开要转换的SSIS项目(或解决方案)文件。在 Windows 8/2012 中,打开 Visual Studio 2012 的 SQL Server Data Tools,如图所示:

“开始页面” 有很多帮助信息,可以通过单击 “视图” 下拉菜单上的 “开始页面” 来查看 “开始页面”,如图所示:

起始页面包括一个打开现有项目的链接(“Open Project…”),如图所示:

SSDT-BI 将转换一个早期版本创建的 SSIS 项目。单击 Open Project 链接,然后浏览到 My_First_SSIS_Project SSIS 项目文件(或解决方案文件),如图所示:

SSDT-BI 警告,这是 单向升级 。一旦名为 My_First_SSIS_Project 的SSIS项目升级到 SSDT-BI 2012 格式后,将无法从 Business Intelligence Development Studio (BIDS)对其进行访问。

打开先前版本中构建的SSIS项目时,将显示下main所示的对话框:

回到过去(2008年),有可能将 SSIS项目 从 SSIS 2005 意外地更新到 SSIS 2008。这对某些开发人员来说很烦人,因为实际情况,几乎没有或根本没有警告说升级即将进行。开发人员抱怨(理所当然的是,这是一个悲剧性的疏忽),Microsoft对此进行了回应,添加了该警告信息的屏幕,以确保开发人员知道此升级是不可逆的。

SSIS项目升级后,您将无法再在以前的开发环境中打开SSIS项目。如果要维护SSIS项目的早期版本,则需要在进行升级之前制作项目的副本。更好的方法,可以考虑使用源代码控制。

每次从 SSDT-BI 中的非本地磁盘源打开SSIS项目时,下图所示的“安全警告”都会显示:

确认安全警告后,将在默认的Web浏览器中显示“迁移报告”,如图所示:

SSIS软件包升级向导(如图9所示)在显示迁移报告的同时启动:

单击下一步按钮继续。下一个屏幕包含要升级的 SSIS 软件包的列表,如图所示。默认情况下,应检查所有软件包,并且应该接受默认设置:

选择要升级的软件包后,单击“下一步”按钮继续。然后会显示用于管理升级的选项,保持默认选项即可:

我很少在 “选择包管理选项”( Select Package Management Options ) 界面上更改默认选择。进行更改时,通常会添加 “验证升级的包”、“创建新包ID”( “Validate upgraded packages”, “Create new package ID” ) 其中的一个或两个。除非同时升级与SSIS包连接的所有服务器,否则不需要更新连接字符串中的提供器( provider )名称(尽管多年来,我一直没有遇到升级提供者名称的问题,因为它们是向后兼容的)。验证升级的包是“双重检查”。会在操作结束时知道升级是否成功。我可能会选择创建一个新的包ID,以使我的SSIS包ID值在企业中保持唯一。

在执行时 —— 从文件系统、msdb数据库或SSIS包存储中执行时 —— 可以设置一个选项来验证包ID。如果在执行此验证的情况下执行SSIS包,则可能要保留原始包ID。通常,我会选中 “软件包失败时继续升级过程” 复选框。如果已开始此过程,则希望它升级尽可能多的包。如果要升级一个或多个SSIS包文件失败,可以手动升级或直接重建。总是将 “忽略配置” 复选框保持选中状态,在包升级完成后手动将SSIS包配置转换为包(或项目)参数。注意:仍然可以在 SSIS 2012 中配置和使用包配置。

单击“下一步”按钮继续。该向导将执行几秒钟(或几分钟),具体取决于要升级的SSIS软件包的数量及其复杂性。完成后,将显示“升级状态”界面,如图所示:

部署模型(Deployment Models)

打开 “My_First_SSIS_Project” —— 刚刚转换的SSIS项目,如图所示:

在解决方案资源管理器中,注意项目名称右边的文字“(package deployment model)”,如图所示:

Microsoft SSIS 团队在支持 SSIS 2012 中的向后兼容性方面做得非常出色。部署模型是这种向后兼容性的很大一部分。当从 SSIS 2008 导入 SSIS 包时,由于"包部署模型",其行为将与2008年完全一样。

包部署模型( Package Deployment Model ) 是 Microsoft 在 2005 至 2008 R2 的 SSIS 版本中用于SSIS包部署、执行和管理的名称。 SSIS 2012 支持包部署模型,即,可以在 SSIS 2012 中运行 SSIS 2008 包。有一些警告(不一定总是有警告),但是它们众所周知并且相对容易解决。例如,在包部署模型( Package Deployment Model )中执行的SSIS包不能利用 SSIS 2012 目录( SSIS 2012 Catalog ),不能使用项目级连接管理器( Project-level Connection Managers ),也不能使用项目或包参数( Project or Package Parameters )。

SSIS 2012 的默认部署模型是 项目部署模型( Project Deployment Model )。 Microsoft提供了在模型之间进行转换的向导。要将 My_First_SSIS_Project 转换为 Project Deployment Model ,请在解决方案资源管理器中右键单击项目名称,然后单击 “转换为项目部署模型”( Convert to Project Deployment Model ),如图所示:

右键,将项目部署模型转换为包部署模型

启动 Project Conversion Wizard ,如图所示:

项目转换向导的第一步是选择包:

下一步,是指定项目属性 —— 项目“保护级别”和“描述”属性( the project Protection Level and Description properties ):

如果SSIS项目包含"执行包任务",则在下一步中它们将升级:

新的项目部署模型是需要更新"执行包任务"的主要原因。 SSIS 2012"执行包任务"包含一个新属性:引用类型( Reference Type )。

与以前的SSIS版本一样,子包可以从 文件系统或msdb数据库( file system or msdb database ) 执行。“引用类型” 属性必须设置为 “外部引用”( External Reference ),才能执行存储在这些位置的子包。要引用与父包包含在相同的项目中的子包,需将“引用类型”设置为“项目引用”( Project Reference )。

通过 "项目转换向导" 中的此步骤,你可以将"包部署模型"的"外部引用"分配给"项目部署模型"的"项目引用"。

向导的接下来的两个步骤使我们能够将 Package Configuration 值转换为 参数( Parameters ),从下图开始:

上图所示的 Configurations 界面和下图所示的 Parameters 界面不适用于 My_First_SSIS_Project ,因为我们没有配置 Package Configurations

由于在上一步中未创建任何参数,因此在下面所示的步骤中没有要配置的参数:

现在我们准备执行转换,如图所示:

转换完成后,将显示一个报告界面,显示转换结果。

同时,还将显示一个对话框,通知用户在 保存项目之前不会保存这些更改 保存项目的最好方法是保存所有内容(单击"文件"->"全部保存")

转换完SSIS项目后,将会出现在 “解决方案资源管理器” 中,项目名称右边的括号中没有文本,如图所示:

在解决方案资源管理器中还要注意几个新的虚拟对象: Project.params 和 "连接管理器"( Connection Managers )。

在本文中,我们使用 SQL Server 2012 Data Tools–BI 将第一个 SSIS 项目 —— My_First_SSIS_Project —— 转换为SSIS 2012;然后将导入的SSIS项目从“包部署模型”转换为“项目部署模型”。

本文主要参考翻译自 The Stairway to Integration Services 系列文章的原文 An Overview of Project Conversion - Level 14 of the Stairway to Integration Services ,目的在于对 SSIS 有一个全面清晰的认识,所有内容在原文的基础上进行实操,由于版本差异、个人疑问等多种原因,未采用完全翻译的原则,同时也会对文中内容进行适当修改,希望最终可以更有利于学习和了解 SSIS,

感谢支持!