此信息适用于 SAP HANA 横向扩容实例。对于纵向扩容和高可用性 1+1 配置,请参阅 Backup and DR Service for SAP HANA。
SAP HANA 横向扩容即时恢复(装载和迁移)
使用 LVM 迁移方法,自动将 HANA 数据从备份/恢复设备暂存磁盘迁移到生产磁盘。在纵向扩容配置或非共享 LVM 多节点横向扩容集群中,在备份/恢复设备暂存磁盘上恢复 SAP HANA 数据库后,使用 LVM 迁移方法。
恢复脚本
恢复脚本为 /act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh
查看脚本详情。
数据库恢复和迁移
开始恢复前的准备工作
- 停止 SAP HANA 数据库(对于横向扩容配置,需要在所有节点上停止)
sapcontrol -nr <instance number> -function StopSystem
sapcontrol -nr <instance number> -function GetSystemInstanceList
- 确保 /etc/fstab 具有 /hana/data 和 /hana/log 装载的 /dev/mapper 条目。
- 使用
df -kh
获取 /hana/data 和 /hana/log 的 /dev/mapper 条目。
- 使用
- 验证 /hana/data 和 /hana/log 是否未被任何进程占用。
- 通过卸载和重新装载 /hana/data 和 /hana/log 进行检查。
- 如果已配置 HANA 快速重启,请注释掉 /etc/fstab 下的 HANA 快速重启条目,并卸载快速重启装载点。在恢复并合并两步装载和迁移的第一步完成后,通过装载快速重启装载点并取消注释快速重启装载点的 /etc/fstab 条目,启用快速重启。
装载映像
使用管理控制台将备份映像装载到目标服务器:
- 以具有管理员权限的用户身份登录管理控制台。
- 选择所需的应用,然后选择访问权限。
- 选择映像,然后点击装载。
- 停用创建新的虚拟应用选项,然后选择相应目标节点或集群。如果装载到横向扩充集群,请确保已启用装载到所有集群服务器选项。
- 提供装载点位置,然后点击提交。
装载作业完成后,映像会装载到目标 HANA 服务器上的指定位置。
装载并迁移使用场景
两个使用场景
一步式装载和迁移。恢复数据库,然后在数据库运行时将数据从备份/恢复设备提供的存储空间迁移到生产存储空间。
两步装载并迁移。恢复数据库的副本。恢复的数据库可从备份/恢复设备运行。当生产存储空间准备就绪后,您可以在数据库运行时开始将数据迁移到生产存储空间。
一步装载和迁移
装载映像后,您可以在一次运行中恢复和迁移数据。
在装载映像的目标服务器上运行此脚本。
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermigrate
如需恢复到特定时间点,请使用
-r
选项:/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermigrate -r <time>
选择此选项后,系统会恢复数据库,将从备份/恢复设备预配的磁盘的卷组与本地存储空间合并,然后开始迁移数据库。
作业成功完成后,系统会在数据库运行期间将数据从备份/恢复设备提供的磁盘移至本地生产存储空间。
如果 HANA 源 SID 和目标 SID 不同
如果 HANA 源 SID 和目标 SID 不同,请在运行 hana_lvm_recover_migrate.sh
脚本之前,将数据和日志装载点中的 SID 目录重命名为目标 SID。
例如:
源 SID:HPR 目标 SID:HSR 挂载点:/mmrestore
- 在运行
hana_lvm_recover_migrate.sh
脚本之前,必须先将 /mmrestore/hana/data 装载点中的目录/mmrestore/hana/data/HPR
重命名为/mmrestore/hana/data/HSR
。 - 在运行
hana_lvm_recover_migrate.sh
脚本之前,必须将 /mmrestore/hana/log 装载点中的目录/mmrestore/hana/log/HPR
重命名为/mmrestore/hana/log/HSR
。
两步装载并迁移
装载映像后,恢复数据库的副本。 恢复的数据库可从备份/恢复设备运行。
运行 recovermerge 选项,以使数据库副本从已装载的映像中运行:
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermerge
如需恢复到特定时间点,请使用
-r
选项:/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermerge -r <time>
成功恢复后,数据库将在备份/恢复设备装载的设备上运行。数据库已启动,可供应用使用。
当生产存储空间可用时,在数据库运行期间开始将数据迁移到生产存储空间。
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh migrate
从备份/恢复设备卸载并删除已装载的映像
- 以具有管理员权限的用户身份登录管理控制台。
- 选择第 1 步中装载的映像。
- 点击卸载并删除。
脚本详细信息 (hana_lvm_recover_migrate.sh)
脚本中包含以下详细信息。
- NAME:SAP HANA 恢复帮助脚本
- 路径:/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh
- 概要:
hana_lvm_recover_migrate.sh <OPERATION> [OPTIONS]
- DESCRIPTION:将 SAP HANA 数据从备份/恢复设备恢复到横向扩容或独立集群。
- OPERATION:指定要执行的操作,此参数为必需参数。
- 合并:合并 Actifio 和生产卷组。
- 迁移:将卷从 Actifio 磁盘迁移到生产磁盘。
- 恢复:运行 Actifio 横向扩展示例恢复脚本。
- RecoverMerge:运行 Recover 和 Merge。
- RecoverMigrate。运行 Recover 和 Migrate。
- 回滚。使集群进入可以再次尝试恢复的状态。
- 测试。可用于测试作业配置。
可选参数
该脚本还提供以下可选参数来替换任何值。
-a \<name\>: mount job name override
-A \<log|params\>: Method to discover job name, log file or params file
-C \<count\>: Expected node count override
-D \<path\>: Path to the HANA data mount point, expected to be the same
for all nodes
-h: Display help documentation and exit, specify operation for more info
-I \<name\>: HANA database SID override
-K \<user\>: HANA keystore user to use for the restore
-L \<path\>: Path to the HANA log mount point, expected to be the same
for all nodes
-r \<time\>: Timepoint to which to recover the HANA database
-R: Assert that the recover script has already been run
-S \<path\>: Path to the shared directory, expected to be the same for
all nodes
-t \<minutes\>: Number of minutes without an update before a job is
considered timed out
-T \<minutes\>: Number of minutes to allow for starting the HANA DB
service
-u \<user\>: HANA service account username \<adm user\>
-v: Enable verbose logging
-V \<version\>: HANA version
-w \<seconds\>: Base wait time, job status checks 1x, file system
operations 4x
脚本选项
恢复
如果您不想将数据迁移到生产存储空间,请运行恢复选项。
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recover
默认情况下,该脚本将从 UDSAgent 日志中提取最新的作业编号,并收集作业所需的所有必要信息,例如目标装载点和数据库 SID。 如果此目标服务器上的最后一个作业不是装载作业,则需要提供最后一个装载作业的 Job #(使用 -a 选项)以替换装载作业的默认值:
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recover -a <Job_#>
对于恢复到特定时间点(使用 -r 选项)
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recover -a <Job_#> -r <time>
成功恢复后,数据库将从备份/恢复设备装载的设备中运行。
合并
当数据库从设备装载的设备运行时,此选项可在从步骤 A 进行恢复操作后运行,以将数据迁移到生产存储空间。在此过程中,数据库会关闭,生产存储的卷组会与备份/恢复设备卷组合并。合并操作成功后,数据库将上线。
如果传递了合并选项,则表示数据库的恢复流程已完成。如果恢复是手动完成的,未使用此脚本,则用户可以指定 -R 选项来确认恢复已运行。如果恢复未完成,脚本不会继续执行合并流程。
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh merge
recovermerge
如果您计划将数据迁移到生产存储空间,请运行 recovermerge 选项。recovermerge 选项是恢复和合并流程的超集,其中合并操作是恢复的一部分。这样可以避免在迁移过程开始时重启数据库。
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermerge
如果此目标服务器上的最后一个作业不是装载作业,则需要使用 -a 选项提供最后一个装载作业的 Job #,以替换装载作业的默认值:
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermerge -a <Job_#>
如需将时间点恢复到特定时间点,请使用 -r 选项:
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermerge -a <Job_#> -r <time>
成功恢复后,脚本会继续运行合并操作,将生产存储的卷组与备份/恢复设备卷组合并。在此过程中,数据库会关闭,合并操作成功后,数据库会重新上线。
migrate
在脚本的恢复或恢复合并运行后运行迁移选项,系统即可开始将数据从备份/恢复设备提供的存储空间迁移到生产存储空间,同时数据库也在运行。
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh migrate
如果恢复未完成,脚本不会继续执行迁移流程。在迁移过程中,脚本会检查合并操作是否完成,然后继续进行迁移,而无需重启数据库;否则,它会将生产存储的卷组与备份/恢复设备的卷组合并。在此过程中,数据库会关闭,合并操作成功后,数据库会重新上线。
recovermigrate
recovermigrate 是 recover、recovermerge 和 migrate 操作的超集。 在此过程中,系统会恢复数据库,将从备份/恢复设备预配的磁盘的卷组与本地存储合并,然后开始数据库迁移。
脚本为 /act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermigrate
。
如果此目标服务器上的最后一个 Job 不是装载,则需要使用 -a 选项提供上次装载作业的 Job 编号,以替换装载作业的默认值:
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermigrate -a <Job_#>
如需将数据库恢复到特定时间点,请使用 -r 选项:
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh recovermigrate -a <Job_#> -r <time>
对于横向扩缩配置,迁移会在集群的所有节点中并行启动。
作业成功完成后,数据会从备份/恢复设备预配的磁盘移至本地生产存储空间,同时数据库也会运行。
回滚
回滚选项会检查作业日志,以确定恢复、合并、迁移、恢复合并或恢复迁移作业的阶段,并还原对数据库服务器所做的任何更改。如果本地生产磁盘与备份/恢复设备暂存磁盘之间的卷组已合并,则从生产卷组中移除暂存磁盘物理卷以执行回滚操作。
/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh rollback
测试
测试操作可用于确保环境配置正确,然后再启动任何实际的恢复操作。由于测试操作不会进行任何更改,因此可以根据需要运行任意次数,也可以完全跳过。
确保在测试运行期间检查以下项目:
- 节点检查;此任务在所有操作中运行。
- 检查预期节点数是否与实际节点数一致。
- 检查非主节点是否具有 SSH 访问权限(如果适用)。
- 检查节点是否可以访问共享目录。
适用于 SAP HANA 横向扩容的 Backup and DR Service 文档
本页是介绍如何使用 Backup and DR Service 保护和恢复 SAP HANA 横向扩容实例的一系列页面之一。如需了解详情,请参阅以下页面:
- 适用于 SAP HANA 横向扩容的 Backup and DR
- 准备 SAP HANA 横向扩容实例以进行备份
- 添加 SAP HANA 横向扩容主机,并发现和保护其数据库
- 为 SAP HANA 横向扩容配置暂存磁盘格式和备份方法
- 为 SAP HANA 横向扩容实例设置应用详情和设置
- 备份 HANA 1+n 和 HANA 横向扩展数据库
- 恢复 SAP HANA 横向扩容实例
- 将 SAP HANA 横向扩容备份装载为标准装载
- 将 SAP HANA 横向扩容备份装载为虚拟数据库
- 装载和迁移 SAP HANA 横向扩容备份,以便立即恢复到任何目标