将SQL 2000日志迁移到SQL Server 2008
您可以迁移SQL Server 2000日志传送配置。本文将介绍执行此操作的方法:
执行带故障转移的迁移可以在升级日志传送配置中的每个服务器时保持数据库的可用性。辅助数据库不需要重新初始化。
执行不带故障转移的迁移是一个比较简单的过程,在此过程中无需故障转移到辅助服务器。如果执行此过程,则数据库在升级主服务器时不可用。辅助数据库不需要重新初始化。
完全重新部署日志传送,包括从一个完整备份中重新初始化辅助数据库。
将日志传送配置迁移到 SQL Server 2008 后,就可以删除由 SQL Server 2000 日志传送创建的表和 SQL Server 代理作业。
注意:
SQL Server 2008 Enterprise 中引入了备份压缩。迁移后的日志传送配置使用“备份压缩默认的”服务器级配置选项控制是否对事务日志备份文件使用备份压缩。可以为每个日志传送配置指定日志备份的备份压缩行为。
限制
在 SQL Server 2000 日志传送配置迁移至 SQL Server 2008 之后,辅助数据库将无法处于备用模式下。
执行带故障转移的迁移
使用故障转移迁移日志传送配置时,会在升级辅助服务器实例期间将主服务器实例暂时保留为 SQL Server 原始版本的实例。升级服务器实例仅会升级联机数据库。脱机数据库(例如日志传送辅助数据库)仍然是 SQL Server 原始版本的数据库。只要数据库保持脱机状态,就可以还原 SQL Server 原始版本的日志备份。
为清晰起见,本过程将 SQL Server 2000 日志传送主服务器实例称为服务器 A,将 SQL Server 2000 日志传送辅助服务器实例称为服务器 B。下图显示了此配置,其中 A 为主服务器实例,B 为单一辅助服务器实例。
将辅助服务器实例 Server B 升级到 SQL Server 2008。升级 Server B 后,日志传送数据库仍然是 SQL Server 2000 数据库,因为它处于脱机状态。此数据库将在下一步升级。复制和还原日志文件的 SQL Server 2000 日志传送作业将不再起作用。
注意:
此时,用户可以继续访问 Server A 上的主数据库。
从主服务器实例(服务器 A)到辅助服务器实例(服务器 B)的故障转移。
若要进行故障转移,请将服务器 A 上的主数据库中所有尚未应用的事务日志备份还原到服务器 B。
对于指定 WITH NORECOVERY 的主数据库上的事务日志,手动执行结尾日志备份。此日志备份捕获任何尚未备份的日志记录并使数据库脱机。
下面的示例在主服务器上备份 AdventureWorks 数据库的日志结尾。此备份文件名为 Failover_AW_20080315.trn:
BACKUP LOG AdventureWorks TO DISK = N'\\FileServer\LogShipping\AdventureWorks\Failover_AW_20080315.trn'WITH NORECOVERY;GO
通过使用 WITH RECOVERY 还原事务日志结尾,使服务器 B 上的辅助数据库联机。
故障转移过程使辅助数据库联机,之后将自动升级到 SQL Server 2008 数据库。数据库升级过程将被完整地记录下来。
注意:
升级 Server B 上的日志传送数据库后,用户即可使用该数据库。但是,除非已在服务器 B 上配置 SQL Server 2008 日志传送,否则不会采用来自服务器 B 上的数据库的日志备份。
将 Server A 升级到 SQL Server 2008。日志传送数据库临时保持为 SQL Server 2000 数据库,因为它处于脱机状态。
在 Server B 上配置 SQL Server 2008 日志传送,将 Server B 作为主服务器,而将 Server A 作为辅助服务器。开始向 Server A 传送事务日志后,当应用了第一个日志备份时,Server A 上的日志传送数据库将升级为 SQL Server 2008 数据库。
重要提示:
在 Server B 上配置日志传送时,请确保在“辅助数据库设置”对话框的“初始化辅助数据库”选项卡上指定“否,辅助数据库已初始化”选项。
(可选)若要使 Server A 重新成为主服务器,则故障转移到 Server A。