挂载和迁移 SAP HANA 横向扩容备份,以便将其即时恢复到任何目标

此信息适用于 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 条目,启用快速重启。

装载映像

  1. 使用管理控制台将备份映像装载到目标服务器:

    1. 以具有管理员权限的用户身份登录管理控制台。
    2. 选择所需的应用,然后选择访问权限
    3. 选择映像,然后点击装载
    4. 停用创建新的虚拟应用选项,然后选择相应目标节点或集群。如果装载到横向扩充集群,请确保已启用装载到所有集群服务器选项。
    5. 提供装载点位置,然后点击提交

装载作业完成后,映像会装载到目标 HANA 服务器上的指定位置。

装载并迁移使用场景

两个使用场景

  • 一步式装载和迁移。恢复数据库,然后在数据库运行时将数据从备份/恢复设备提供的存储空间迁移到生产存储空间。

  • 两步装载并迁移。恢复数据库的副本。恢复的数据库可从备份/恢复设备运行。当生产存储空间准备就绪后,您可以在数据库运行时开始将数据迁移到生产存储空间。

一步装载和迁移

装载映像后,您可以在一次运行中恢复和迁移数据。

  1. 在装载映像的目标服务器上运行此脚本。

    /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>

    选择此选项后,系统会恢复数据库,将从备份/恢复设备预配的磁盘的卷组与本地存储空间合并,然后开始迁移数据库。

  2. 作业成功完成后,系统会在数据库运行期间将数据从备份/恢复设备提供的磁盘移至本地生产存储空间。

如果 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

两步装载并迁移

装载映像后,恢复数据库的副本。 恢复的数据库可从备份/恢复设备运行。

  1. 运行 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>

    成功恢复后,数据库将在备份/恢复设备装载的设备上运行。数据库已启动,可供应用使用。

  2. 当生产存储空间可用时,在数据库运行期间开始将数据迁移到生产存储空间。

/act/custom_apps/saphana/lvm_migrate/hana_lvm_recover_migrate.sh migrate

从备份/恢复设备卸载并删除已装载的映像

  1. 以具有管理员权限的用户身份登录管理控制台。
  2. 选择第 1 步中装载的映像。
  3. 点击卸载并删除

脚本详细信息 (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:运行 RecoverMerge
  • RecoverMigrate。运行 RecoverMigrate
  • 回滚。使集群进入可以再次尝试恢复的状态。
  • 测试。可用于测试作业配置。

可选参数

该脚本还提供以下可选参数来替换任何值。

    -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 横向扩容实例的一系列页面之一。如需了解详情,请参阅以下页面: