DPM 2012R2。在 Windows Server 2012R2 上使用 CSV 的 Hyper-V 故障转移群集。来宾也是带有 SQL Server 2014 的 Windows Server 2012R2。所有最新更新、更新汇总、累积更新和一些推荐的修补程序。
故事:VM 来宾中的每个 SQL 安装都有自己的维护计划,其中包含完整、差异和日志数据库备份到网络共享。现在我在 DPM 的帮助下为虚拟机添加保护。
会发生什么:每次 DPM 备份 VM 时,它都会使用 VSS,该 VSS 会命中 SQL VSS Writer,而后者又会在 SQL 中执行备份。
什么不好:这个 VSS 备份是数据库的完整备份,会产生所有后果。因此,现在无法使用自己的 SQL 备份,因为无法从处于 IN RECOVERY 状态的 VM VHDx 还原 SQL 数据库以应用差异或日志备份。有一种方法只能恢复 mdf/ndf/ldf 文件并附加它们或整个 VM。
如 SQL VSS Writer 文档中所述,它不支持日志备份,因此不存在生产数据库无法接受的时间点恢复。(https://msdn.microsoft.com/en-us/library/ms175536.aspx)
我看到的唯一方法是仅制作此备份副本。SQL VSS 编写器支持它。VSS 本身支持这个参数 VSS_BACKUP_TYPE 到 VSS_BT_COPY
但我看不到告诉 DPM 这样做的方法。
到目前为止我尝试了什么:
内部虚拟机客户操作系统
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SQLWriter\Settings\ 。DWORD DisableLogShrink 1。仅在 SQL VSS 备份期间禁用 Log Shrink,但它仍然是完整备份。
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Virtualization\VssRequestor\ 。DWORD 备份类型 1 。KB975354。如果创建此注册表项并将其值设置为 1,则应用程序备份将不受运行 Hyper-V 的服务器上的虚拟机备份操作的影响。没有效果。
在主机服务器上(集群中的所有节点都重新启动)
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft Data Protection Manager\Agent\HonorFilesNotToBackup\ Plus HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\BackupRestore\FilesNotToBackup\ MULTI_SZ 字符串,带有指向包含 SQL 数据库的 VHDX 的路径。没有效果。
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft Data Protection Manager\Agent\2.0\ 。DWORD CopyBackupEnabled 1. ( https://blogs.technet.microsoft.com/dpm/2015/05/20/an-in-depth-look-at-the-registry-settings-that-c ontrol-microsoft-dpm-2012 / ) 没有效果。
在 DPM 服务器上
- HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft Data Protection Manager\Agent\2.0\CopyBackups\
DWORD DPM 中 VM 的名称,值为 1。
也许就是这样,我只是不知道如何正确编写 DPM 将接受的 VM 名称。现在它在共振峰 VMNAME.CLUSTERNAME.DOMAIN.COM 没有效果。
好像我的 google-bing-whatever-fu 在这里结束了。
它给我留下了几个问题。- 如何使用 SQL 保护 VM 并保存使用 DPM 对其中的 SQL 数据库进行时间点恢复的能力?- 所有其他人如何使用 DPM 使用 SQL 保护他们的 VM?对整个 VM 使用 15 分钟的同步间隔?在数以万计的虚拟机的情况下,它会占用大量空间/负载/流量等
主要问题: - 有没有人能够实现 DPM 不会影响同一设置中 Hyper-V VM 内的 SQL 备份?
您可以通过禁用 SQL Server 的“SQL Server VSS 编写器”服务来停止使用 SQL VSS 编写器。
出色地。我终于做到了。
真正对我有用的是:
在主机服务器上
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft Data Protection Manager\Agent\2.0
DWORD CopyBackupEnabled 1
这确实使 VSS 备份仅复制,但它们仍然记录在备份历史中(不知何故我没想到会这样并忽略了它确实有效)。
其次,默认情况下,在客户机操作系统 WS2012R2 中,日志不会被截断,但相反,在 2008R2 中,它们默认会被截断。
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Virtualization\VssRequestor DWORD BackupType 1
对 SQL 没有影响,但 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SQLWriter\Settings\ DWORD DisableLogShrink 1
确实有帮助
日志截断由 fn_dblog() 或日志大小检查。
此外,
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft Data Protection Manager\Agent\HonorFilesNotToBackup
Plus
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\BackupRestore\FilesNotToBackup
MULTI_SZ 字符串与 VHDX 的路径未按
预期工作。
使用这些密钥时,VHDX 文件仍会受到 VSS 的影响,但它们会从生成的备份中排除。因此,如果使用这些密钥请注意,即使排除了带有 DB 的 VHDX(或者仅排除了数据库文件),SQL 也会记录此备份并可能截断日志。
最后,DPM 服务器键
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft Data Protection Manager\Agent\2.0\CopyBackups
DWORD 数据源名称
不影响 VM 备份,看起来共享点配置数据库是该键的唯一目标