在 Compute Engine 上克隆 Microsoft SQL Server 数据库


本教程介绍了克隆在 Compute Engine 上运行的 Microsoft SQL Server 数据库的两种方法。一种方法是使用永久性磁盘快照。另一种方法是使用本机 SQL Server 备份和恢复功能,通过 Cloud Storage 传输备份内容。Cloud Storage 是 Google Cloud 的对象存储服务。它提供的文件存储服务直观、耐用、安全性更高且可用性高。

克隆是将在线数据库复制到其他服务器的过程。副本独立于现有数据库,并以时间点快照的形式保存。您可以将克隆的数据库用于各种用途,不会为生产服务器增加负担,也不会损害生产数据的完整性。其中一些用途包括:

  • 执行分析查询
  • 对应用进行负载测试或集成测试
  • 提取数据以用于填充数据仓库
  • 利用数据运行实验

本教程中介绍的每种克隆方法各有其优缺点,理想方法取决于您的具体情况。下表列出了一些重要问题。

问题 方法 1:磁盘快照 方法 2:使用 Cloud Storage 进行备份和恢复
SQL Server 实例是否需要额外的磁盘空间 无需额外的磁盘空间 在进行创建和恢复操作时需要额外的空间来存储备份文件
克隆过程中是否给源 SQL Server 实例增加额外的负载 没有额外负载 创建和上传备份文件时会为 CPU 和 I/O 增加额外负载
克隆的持续时间 大型数据库的克隆速度相对较快 大型数据库的克隆速度相对较慢
是否可从 Google Cloud 外部的 SQL Server 实例进行克隆
复杂性 需要一系列复杂的命令来挂接克隆的磁盘 只需一组相对简单的命令来进行克隆
是否可以利用现有备份系统 是(如果备份系统使用 Google Cloud 磁盘快照) 是(如果备份系统将本机 SQL Server 备份文件写入 Cloud Storage)
克隆的粒度 只能克隆整个磁盘 只能克隆指定数据库
数据一致性 在快照点一致 在备份时一致

本教程假设您熟悉 Microsoft Windows 系统管理、PowerShell 以及使用 Microsoft SQL Server Management Studio 管理 Microsoft SQL Server。

目标

  • 学习如何在 Google Cloud 上运行 SQL Server 实例。
  • 学习如何在辅助磁盘上创建演示数据库。
  • 学习如何使用 Compute Engine 磁盘快照克隆 SQL Server 数据库。
  • 学习如何通过使用 Cloud Storage 传输备份内容来克隆 SQL Server 数据库。

费用

在本文档中,您将使用 Google Cloud 的以下收费组件:

您可使用价格计算器根据您的预计使用情况来估算费用。 Google Cloud 新用户可能有资格申请免费试用

完成本文档中描述的任务后,您可以通过删除所创建的资源来避免继续计费。如需了解详情,请参阅清理

准备工作

  1. 登录您的 Google Cloud 账号。如果您是 Google Cloud 新手,请创建一个账号来评估我们的产品在实际场景中的表现。新客户还可获享 $300 赠金,用于运行、测试和部署工作负载。
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  3. 确保您的 Google Cloud 项目已启用结算功能

  4. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  5. 确保您的 Google Cloud 项目已启用结算功能

  6. 启用 Compute Engine API。
  7. 启用 API

确保您满足以下额外的前提条件:

  • 您使用的是 Google Chrome 浏览器。
  • 安装您选择的远程桌面协议 (RDP) 客户端。如需了解详情,请参阅 Microsoft 远程桌面客户端。 如果您已安装 RDP 客户端,则可以跳过此任务。

设置环境

如需完成本教程,您需要为计算环境设置以下内容:

  • Compute Engine 上一个名为 sql-server-prod 的 SQL Server 实例,用于表示生产数据库服务器。
  • 挂接到生产服务器的一个额外磁盘(名为 sql-server-prod-data),用于存储生产数据库。
  • Wide World Importers SQL Server 示例数据库的一个副本,用于模拟要克隆的生产数据库。
  • Compute Engine 上一个名为 sql-server-test 的 SQL Server 实例,用于表示您的测试数据库服务器。数据库就是克隆到此服务器上。

下图说明了此架构。

显示本教程中用于克隆 SQL Server 数据库的设置的图表。

创建生产虚拟机实例

如需模拟生产环境,请在 Windows Server 上设置一个运行 SQL Server 的 Compute Engine 虚拟机实例。

本教程的虚拟机实例使用了两个磁盘:一个磁盘 50 GB,用于操作系统和用户账号;一个磁盘 100 GB,用于存储数据库。

在 Compute Engine 中,使用单独的磁盘不会带来任何性能优势。磁盘性能取决于挂接到实例的所有磁盘的总存储容量,以及虚拟机实例上的 vCPU 总数。因此,数据库和日志文件可以位于同一磁盘上。

控制台

  1. 在 Google Cloud 控制台中,转到虚拟机实例页面。

    转到“虚拟机实例”页面

  2. 点击创建

  3. 名称字段中,输入 sql-server-prod

  4. 对于地区,选择 us-east1

  5. 对于区域,选择 us-east1-b

  6. 机器配置下,将机器类型更改为 n1-standard-2(2 个 vCPU)。

  7. 启动磁盘说明旁边,点击更改

  8. 启动磁盘面板中,点击公共映像标签页。

  9. 操作系统下拉列表中,选择 Windows Server 上的 SQL Server (SQL Server on Windows Server)。

  10. 版本下拉列表中,选择 Windows Server 2022 Datacenter 上的 SQL Server 2022 Standard (SQL Server 2022 Standard on Windows Server 2022 Datacenter)。

  11. 确保已设置以下值:

    • 启动磁盘类型设置为标准永久性磁盘
    • 大小 (GB) 设为 50
  12. 点击选择

  13. 身份和 API 访问权限下,将访问权限范围设置为允许所有 Cloud API 的全面访问权限

  14. 展开管理、安全、磁盘、网络、单独租用

  15. 点击磁盘标签页。

  16. 点击添加新磁盘

  17. 名称字段中,输入 sql-server-prod-data

  18. 大小 (GB) 字段中,输入 100

  19. 点击完成

  20. 点击创建

Cloud Shell

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 初始化以下变量:

    VPC_NAME=VPC_NAME
    SUBNET_NAME=SUBNET_NAME
    

    其中:

    • VPC_NAME:您的 VPC 的名称
    • SUBNET_NAME:您的子网的名称
  3. 设置默认项目 ID

    gcloud config set project PROJECT_ID
    

    PROJECT_ID 替换为您的 Google Cloud 项目的 ID。

  4. 设置默认区域:

    gcloud config set compute/region REGION
    

    REGION 替换为要在其中部署的区域的 ID。

  5. 设置默认可用区:

    gcloud config set compute/zone ZONE
    

    ZONE 替换为要在其中部署的可用区的 ID。

  6. 用 Windows Server 2022 Datacenter 上的 SQL Server 2022 Standard 应用映像,创建一个 Compute Engine 实例:

    REGION=$(gcloud config get-value compute/region)
    ZONE=$(gcloud config get-value compute/zone)
    
    gcloud compute instances create sql-server-prod \
        --machine-type=n1-standard-2 \
        --scopes=cloud-platform \
        --image-family=sql-std-2022-win-2022 \
        --image-project=windows-sql-cloud \
        --boot-disk-size=50GB \
        --boot-disk-device-name=sql-server-prod \
        --create-disk="mode=rw,size=100,type=pd-standard,name=sql-server-prod-data,device-name=sql-server-prod-data" \
        --subnet=$SUBNET_NAME
    

    此命令授予此实例对 Google Cloud API 的完整访问权限,创建一个 100 GB 的辅助磁盘,并将该磁盘挂接到此实例。忽略磁盘性能警告,因为本教程不需要高性能。

连接到虚拟机实例

  1. 在 Google Cloud 控制台中,转到虚拟机实例页面。

    转到“虚拟机实例”页面

  2. 等待虚拟机实例准备就绪,大约需要 5 分钟。

    如需监控虚拟机的初始化过程,请在 Cloud Shell 中查看其串行端口输出:

    gcloud compute instances tail-serial-port-output sql-server-prod
    

    出现以下消息后,即表示初始化操作已完成。

    Instance setup finished. sql-server-prod is ready to use.
    

    Control+C 即可停止监控串行端口。

  3. 点击实例名称 sql-server-prod,打开虚拟机实例详情页面。

  4. 远程访问下,点击设置 Windows 密码,然后点击设置,在远程机器上创建您的账号。

    此步骤会为您生成密码。记下此密码或将其复制到安全的临时文件中。

  5. 在 Google Cloud 控制台的 Compute Engine 部分,点击 RDP 下拉列表,然后选择 下载 RDP 文件选项以下载实例的 RDP 文件。

    使用此文件通过 RDP 客户端连接到实例。如需了解详情,请参阅 Microsoft 远程桌面客户端

  6. 收到提示时,输入您刚刚生成的密码,然后点击确定

  7. 如需接受服务器证书并登录到远程 Windows 实例,请点击继续

  8. 当系统提示您是否希望网络上的其他 PC 和设备可以发现您的计算机时,点击

设置额外的磁盘

挂接到生产实例的第二个磁盘用于存储生产数据库。此磁盘为空白状态,因此您需要对其进行分区、格式化和装载。

  1. 在连接到 sql-server-prod 实例的 RDP 会话中,点击 Windows 任务栏上的开始按钮,输入 diskpart,然后点击 diskpart 来打开 DiskPart。
  2. 当系统提示是否允许应用进行更改时,点击
  3. 显示挂接到实例的磁盘列表:

    list disk
    

    输出如下所示:

    Disk ###  Status         Size     Free     Dyn  Gpt
    --------  -------------  -------  -------  ---  ---
    Disk 0    Online           50 GB      0 B
    Disk 1    Online          100 GB   100 GB
    

    磁盘 1 (100 GB) 是数据磁盘。

  4. 选择数据磁盘:

    select disk 1
    
  5. 初始化此磁盘:

    clean
    
  6. 创建一个 GUID 分区表

    convert gpt
    
  7. 创建数据分区,令其使用整个磁盘:

    create partition primary
    
  8. 列出可用的卷:

    list volume
    

    输出如下所示:

    Volume ###  Ltr  Label        Fs     Type        Size     Status     Info
    ----------  ---  -----------  -----  ----------  -------  ---------  --------
    Volume 0     C                NTFS   Partition     49 GB  Healthy    Boot
    Volume 1                      FAT32  Partition    100 MB  Healthy    System
    Volume 2                      RAW    Partition     99 GB  Healthy
    

    卷 2 (99 GB) 是数据磁盘。

  9. 选择该卷:

    select volume 2
    
  10. 使用 NTFS 文件系统格式化该分区并为其设置 data 标签:

    format quick fs=ntfs label=data
    
  11. 将该磁盘装载为 D 盘:

    assign letter=d
    
  12. 退出 DiskPart:

    exit
    

下载示例数据库

如需为此克隆练习设置环境,您需要执行以下操作:

若要创建目录并下载备份文件,请按照以下步骤操作:

  1. 在 RDP 会话中,点击 Windows 任务栏上的开始按钮,输入 PowerShell,然后选择 Windows PowerShell 应用。

  2. 在 PowerShell 提示符下,创建一个目录结构来存储此数据库:

    mkdir D:\sql-server-data\wideworldimporters
    
  3. 将备份文件下载到 D 盘:

    bitsadmin /transfer sampledb /dynamic /download /priority FOREGROUND `
      https://github.com/Microsoft/sql-server-samples/releases/download/wide-world-importers-v1.0/WideWorldImporters-Full.bak `
      D:\sql-server-data\WideWorldImporters-Full.bak
    

恢复示例数据库

您需要将示例数据库恢复到 D 盘 (data),可以通过使用 Microsoft SQL Server Management Studio (SSMS) 向导以交互式方式完成,或者运行 Transact-SQL 命令直接恢复。

SSMS 向导

  1. 在 RDP 会话中,点击 Windows 任务栏上的开始按钮,输入 ssms,然后选择 Microsoft SQL Server Management Studio(以管理员身份运行)
  2. 应用启动后,点击 Connect 以使用 Windows 身份验证连接到 sql-server-prod 数据库引擎。
  3. 在 Object Explorer 中,右键点击 Databases,然后选择 Restore Database
  4. Source 下,选择 Device,然后点击设备名称旁边的 [...] 按钮。
  5. Select backup devices 对话框中,确保为 Backup media type 选择了 File,然后点击 Add
  6. 在文件选择器中,浏览至 D:\sql-server-data,点击 WideWorldImporters-Full.bak 文件,然后点击 OK
  7. 点击 OK 关闭 Select backup devices 对话框。

    Restore Database 对话框现在填充了关于 Wide World Importers 数据库备份的数据。

  8. Select a page 下,点击 Files

  9. 选中 Relocate all files to folder 复选框。

  10. Data file folderLog file folder 字段中,输入 D:\sql-server-data\wideworldimporters

    显示 Restore Database 对话框的屏幕截图。

  11. 点击 OK 开始执行恢复操作。

几分钟后,您会注意到数据库已恢复。

Transact-SQL

  1. 在 RDP 会话中,点击 Windows 任务栏上的开始按钮,输入 ssms,然后选择 Microsoft SQL Server Management Studio(以管理员身份运行)
  2. 应用启动后,点击 Connect 以使用 Windows 身份验证连接到 sql-server-prod 数据库引擎。
  3. 选择 File > New > Query with Current Connection 以打开新的查询窗口。
  4. 利用您下载的备份文件发起恢复:

    USE [master]
    GO
    
    RESTORE DATABASE [WideWorldImporters]
      FROM  DISK = N'D:\SQL-SERVER-DATA\WideWorldImporters-Full.bak'
      WITH  FILE = 1,
      MOVE N'WWI_Primary' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters.mdf',
      MOVE N'WWI_UserData' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters_UserData.ndf',
      MOVE N'WWI_Log' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters.ldf',
      MOVE N'WWI_InMemory_Data_1' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters_InMemory_Data_1',
      NOUNLOAD,
      STATS = 5
    GO
    

    此命令会将数据库和日志文件恢复到 D:\sql-server-data\wideworldimporters 目录中。

  5. 右键点击查询代码并点击 Execute

    等待数据库完成恢复,这可能需要几分钟。您可以在 Object Explorer 中点击 Refresh ,查看该数据库是否在数据库树中列出。数据库恢复完成后,您可以关闭查询窗口而不保存。

如需验证示例数据库是否能正常运行,您可以运行一个查询。

  1. 在 Microsoft SQL Server Management Studio 中,选择 File > New > Query with Current Connection 以打开新的查询窗口,然后复制以下代码:

    SELECT top(100)
      i.InvoiceDate, i.InvoiceID, i.CustomerID, c.CustomerName,
      i.ConfirmedDeliveryTime, i.ConfirmedReceivedBy
    FROM
      WideWorldImporters.Sales.Invoices i
      JOIN WideWorldImporters.Sales.Customers c
      ON i.CustomerID=c.CustomerID
    WHERE i.ConfirmedDeliveryTime IS NOT NULL
    ORDER BY i.InvoiceDate desc;
    

    此查询从最近交付的 100 个账单中检索汇总信息。

  2. 右键点击查询窗口,然后点击 Execute

    Results 窗格显示摘要信息。

    显示查询示例数据库的结果空格的屏幕截图。

创建测试虚拟机实例

在本部分中,您将创建一个名为 sql-server-test 的 SQL Server 实例,作为克隆数据库的目的地。此实例的配置与生产实例相同。但是,您不必创建第二个数据磁盘,而是稍后在本教程中挂接数据磁盘。

控制台

  1. 转到虚拟机实例页面。

    前往“虚拟机实例”页面

  2. 点击创建

  3. 名称字段中,输入 sql-server-test

  4. 对于地区,选择 us-east1

  5. 对于区域,选择 us-east1-b

  6. 机器配置下,将机器类型更改为 n1-standard-22 个 vCPU)。

  7. 启动磁盘映像旁边,点击更改

  8. 启动磁盘面板中,点击公共映像标签页。

  9. 操作系统下拉列表中,选择 Windows Server 上的 SQL Server (SQL Server on Windows Server)。

  10. 版本下拉列表中,选择 Windows Server 2022 Datacenter 上的 SQL Server 2022 Standard (SQL Server 2022 Standard on Windows Server 2022 Datacenter)。

  11. 确保已设置以下值:

    • 启动磁盘类型设置为标准永久性磁盘
    • 大小 (GB) 设为 50
  12. 点击选择

  13. 身份和 API 访问权限下,将访问权限范围设置为允许所有 Cloud API 的全面访问权限

  14. 点击创建

Cloud Shell

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 创建测试 SQL Server 实例:

    gcloud compute instances create sql-server-test \
        --machine-type=n1-standard-2 \
        --scopes=cloud-platform \
        --image-family=sql-std-2022-win-2022 \
        --image-project=windows-sql-cloud \
        --boot-disk-size=50GB \
        --boot-disk-device-name=sql-server-test \
        --subnet=$SUBNET_NAME
    

    您可以忽略磁盘性能警告,因为本教程不需要高性能。

连接到虚拟机实例

  1. 在 Google Cloud 控制台中,转到虚拟机实例页面。

    转到“虚拟机实例”页面

  2. 等待虚拟机实例准备就绪,大约需要 5 分钟。

    如需监控虚拟机的初始化过程,请在 Cloud Shell 中查看其串行端口输出:

    gcloud compute instances tail-serial-port-output sql-server-prod
    

    出现以下消息后,即表示初始化操作已完成。

    Instance setup finished. sql-server-test is ready to use.
    

    Control+C 即可停止监控串行端口。

  3. 点击实例名称 sql-server-test 以打开虚拟机实例详情页面。

  4. 远程访问下,点击设置 Windows 密码,然后点击设置,在远程机器上创建您的账号。

    此步骤会为您生成密码。记下此密码或将其复制到安全的临时文件中。

  5. 在 Google Cloud 控制台的 Compute Engine 部分,点击 RDP 下拉列表,然后选择 下载 RDP 文件选项以下载实例的 RDP 文件。

    使用此文件通过 RDP 客户端连接到实例。如需了解详情,请参阅 Microsoft 远程桌面客户端

  6. 收到提示时,输入您刚刚生成的密码,然后点击确定

  7. 如需接受服务器证书并登录到远程 Windows 实例,请点击继续

  8. 当系统提示您是否允许其他 PC 或设备发现您的 PC 时,点击

使用 Compute Engine 磁盘快照克隆数据库

如需克隆在 Compute Engine 上运行的 SQL Server 数据库,一种方法是将数据库存储在单独的数据磁盘中,并使用永久性磁盘快照来创建该磁盘的克隆。

利用永久性磁盘快照,您可以获得磁盘上的数据在某个时间点的副本。安排磁盘快照是自动备份数据的一种方法。

在本教程的这一部分,您将执行以下操作:

  • 截取生产服务器的数据磁盘的快照。
  • 根据该快照创建一个新的磁盘。
  • 将新磁盘装载到测试服务器上。
  • 将此磁盘上的数据库挂接到测试实例上的 SQL Server。

以下图表展示如何使用磁盘快照克隆数据库。

展示使用磁盘快照克隆 SQL Server 数据库的设置的图表。

创建磁盘快照

控制台

  1. 在 Google Cloud 控制台中,转到虚拟机实例页面。

    转到“虚拟机实例”页面

  2. 点击 sql-server-prod 实例的名称。

  3. 虚拟机实例详情页面中,点击磁盘 sql-server-prod-data

  4. 点击创建快照

  5. 将该快照命名为 sql-server-prod-data-snapshot

  6. 对于位置,选择地区级

  7. 验证该地区是否设置为 us-east1(与虚拟机实例的设置相同)。

  8. 选中启用 VSS 选项。

    此选项使用 Microsoft Windows 中的卷影复制服务来截取一致的快照。

  9. 点击创建

    几分钟后,快照即创建完成。

Cloud Shell

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 在虚拟机实例所在的区域中创建数据磁盘的快照:

    gcloud compute disks snapshot sql-server-prod-data \
         --snapshot-names=sql-server-prod-data-snapshot \
         --guest-flush \
         --zone="${ZONE}"
    

    --guest-flush 选项使用 Microsoft Windows 中的卷影复制服务来创建一致的快照。几分钟后,快照即创建完成。

将磁盘快照挂接到测试实例

您需要利用创建的快照来创建新的数据磁盘,然后将其挂接到 sql-server-test 实例。

控制台

在以下步骤中,您会创建一个新的永久性磁盘,将生产磁盘的快照用作其内容,然后将其挂接到到测试实例。

  1. 在 Google Cloud 控制台中,转到虚拟机实例页面。

    转到“虚拟机实例”页面

  2. 点击实例名称 sql-server-test

  3. 虚拟机实例详情页面上,点击修改

  4. 点击添加新磁盘

  5. 将新磁盘命名为 sql-server-test-data

  6. 对于来源类型,选择快照

  7. 对于您创建的 sql-server-prod-data-snapshot 实例,选择来源快照

  8. 确保模式设置为读写

  9. 点击完成

Cloud Shell

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 创建新的永久性磁盘,使用生产磁盘的快照作为其内容:

    gcloud beta compute disks create sql-server-test-data \
         --size=100GB \
         --source-snapshot=sql-server-prod-data-snapshot \
         --zone="${ZONE}"
    
  3. 利用读写权限将新磁盘挂接到 sql-server-test 实例:

    gcloud compute instances attach-disk sql-server-test \
        --disk=sql-server-test-data --mode=rw
    

在 Windows 中装载新的数据磁盘

您创建的磁盘已挂接到虚拟机实例,但仍是脱机状态,并且该卷被设置为只读。如需将该卷设置为读写且可装载,请执行以下步骤:

  1. 在连接到 sql-server-test 实例的 RDP 客户端窗口中,点击 Windows 任务栏上的开始按钮,输入 diskpart,然后点击 diskpart 来打开 DiskPart。
  2. 当系统提示是否允许应用进行更改时,点击
  3. 显示挂接到实例的磁盘的清单:

    list disk
    

    输出如下所示:

    
    Disk ###  Status         Size     Free     Dyn  Gpt
    --------  -------------  -------  -------  ---  ---
    Disk 0    Online           50 GB      0 B
    Disk 1    Offline         100 GB      0 B       *
     

    数据磁盘(磁盘 1,100 GB)为脱机状态。

  4. 选择数据磁盘:

    select disk 1
    
  5. 将磁盘联机,具体命令如下:

    online disk
    
  6. 列出可用的卷:

    list volume
    

    输出如下所示:

    Volume ###  Ltr  Label        Fs     Type        Size     Status     Info
    ----------  ---  -----------  -----  ----------  -------  ---------  --------
    Volume 0     C                NTFS   Partition     49 GB  Healthy    Boot
    Volume 1                      FAT32  Partition    100 MB  Healthy    System
    Volume 2                      RAW    Partition     99 GB  Healthy
    

    卷 2 (99 GB) 是数据卷。它被列为 Hidden 状态,并且未分配盘符。

  7. 选择该卷:

    select volume 2
    
  8. 清除您利用快照创建该卷时设置的特性:

    attr volume clear readonly hidden nodefaultdriveletter shadowcopy
    

    此命令使卷可装载。

  9. 将该卷作为 D 盘装载:

    assign letter=d
    
  10. 退出 DiskPart:

    exit
    

重置文件所有权和权限

由于您是利用 sql-server-prod 实例上的快照创建的数据磁盘,因此文件所有权和权限的用户 ID 与 sql-server-test 实例的设置不同。您需要将文件的所有权更改为 sql-server-test 实例上的用户,并更新权限以便您的本地用户和 MSSQLSERVER 用户可以读取这些文件。

  1. 在连接到 sql-server-test 实例的 RDP 客户端窗口中,点击 Windows 任务栏上的开始按钮,然后输入 cmd
  2. 以管理员身份打开命令提示符应用。
  3. sql-server-data 文件夹下的文件的所有者设置为 MSSQLSERVER 服务用户:

    icacls d:\sql-server-data /setowner "nt service\mssqlserver" /t
    
  4. 在顶级 sql-server-data 文件夹中重置所有文件的所有权限:

    icacls d:\sql-server-data /reset /t
    
  5. 更新 sql-server-data 文件夹的访问控制列表 (ACL):

    icacls d:\sql-server-data /grant Administrators:(oi)(ci)f "nt service\mssqlserver":(oi)(ci)f "owner rights":(oi)(ci)f  %USERNAME%:(oi)(ci)f
    
  6. 从驱动器的根文件夹中停用继承,以便仅应用前述权限:

    icacls d:\sql-server-data /inheritancelevel:r
    
  7. 退出命令提示符应用:

    exit
    

现在,sql-server-test 实例上的本地用户和 SQL Server 实例便可以访问此数据库文件了。

挂接克隆的数据库

现在,将 D 盘 (data) 上克隆的数据库挂接到测试 SQL Server 实例。可以使用 Microsoft SQL Server Management Studio 向导以交互式方式挂接此数据库,或者运行 Transact-SQL 命令直接挂接。

SSMS 向导

  1. 在连接到 sql-server-test 实例的 RDP 会话中,点击 Windows 任务栏上的开始按钮,输入 ssms,然后选择 Microsoft SQL Server Management Studio(以管理员身份运行)
  2. 点击 Connect 以使用 Windows 身份验证连接到 sql-server-test 数据库引擎。
  3. 在 Object Explorer 中,右键点击 Databases,然后选择 Attach
  4. Attach Databases 向导中,点击 Add
  5. 浏览至 D:\sql-server-data\wideworldimporters 目录,点击 WideWorldImporters.mdf 文件,然后点击 OK
  6. 点击 OK 即可挂接此数据库。

    片刻之后,克隆数据库即会挂接。您可以在 Object Explorer 中点击 Refresh ,查看该数据库是否在数据库树中列出。

Transact-SQL

  1. 在连接到 sql-server-test 实例的 RDP 会话中,点击 Windows 任务栏上的开始按钮,输入 ssms,然后选择 Microsoft SQL Server Management Studio(以管理员身份运行)
  2. 点击 Connect 以使用 Windows 身份验证连接到 sql-server-prod 数据库引擎。
  3. 选择 File > New > Query with Current Connection 以打开新的查询窗口。
  4. 挂接 D:\sql-server-data\wideworldimporters 目录中的数据和日志文件:

    USE [master]
    GO
    
    CREATE DATABASE [WideWorldImporters] ON
    ( FILENAME = N'D:\sql-server-data\wideworldimporters\WideWorldImporters.mdf' ),
    ( FILENAME = N'D:\sql-server-data\wideworldimporters\WideWorldImporters.ldf' ),
    ( FILENAME = N'D:\sql-server-data\wideworldimporters\WideWorldImporters_UserData.ndf' )
     FOR ATTACH
    GO
    
  5. 右键点击查询代码并点击 Execute

    片刻之后,克隆数据库即会挂接。您可以在 Object Explorer 中点击 Refresh ,查看该数据库是否在数据库树中列出。挂接数据库后,您可以关闭查询窗口而不保存。

如需验证示例数据库是否能正常运行,您可以运行一个查询。

  1. 在 SQL Server Management Studio 中,选择 File > New > Query with Current Connection 以打开新的查询窗口,然后复制以下代码:

    SELECT top(100)
      i.InvoiceDate, i.InvoiceID, i.CustomerID, c.CustomerName,
      i.ConfirmedDeliveryTime, i.ConfirmedReceivedBy
    FROM
      WideWorldImporters.Sales.Invoices i
      JOIN WideWorldImporters.Sales.Customers c
      ON i.CustomerID=c.CustomerID
    WHERE i.ConfirmedDeliveryTime IS NOT NULL
    ORDER BY i.InvoiceDate desc;
    

    此查询从最近交付的 100 个账单中检索汇总信息。

  2. 如需运行查询,右键点击查询窗口,然后选择 Execute

    Results 窗格显示摘要信息。

    显示查询示例数据库的结果空格的屏幕截图。

现在,您已了解了如何使用永久性磁盘快照克隆数据库,可以试试使用备份和还原来克隆数据库。如需完成本教程中的第二种方法,您必须删除从 sql-server-test 实例克隆的数据库。

删除克隆的数据库

如需删除使用磁盘快照创建的克隆数据库,请执行以下步骤。

SSMS 向导

  1. 在连接到 sql-server-test 实例的 RDP 会话中,打开 Microsoft SQL Server Management Studio,然后连接到 sql-server-test 数据库引擎。
  2. 在 Object Explorer 中,展开 Databases,右键点击 WorldWideImporters 数据库,然后选择 Delete
  3. Delete Object 向导中,确保选中 Close existing connections 复选框。
  4. 点击 OK

Transact-SQL

  1. 在连接到 sql-server-test 实例的 RDP 会话中,打开 Microsoft SQL Server Management Studio,然后连接到 sql-server-test 数据库引擎。
  2. 若要关闭与 WideWorldImporters 数据库的所有连接并将其删除,请将以下脚本复制到新的查询窗口中,右键点击代码,然后点击 Execute

    USE [master]
    GO
    ALTER DATABASE [WideWorldImporters] SET SINGLE_USER WITH ROLLBACK IMMEDIATE
    GO
    DROP DATABASE [WideWorldImporters]
    GO
    

    删除数据库后,您可以关闭查询窗口而不保存。您可以在 Object Explorer 中点击 Refresh 来确认数据库已经删除。

使用备份和还原进行克隆

克隆在 Compute Engine 上运行的 SQL Server 数据库的第二种方法是使用本机 SQL Server 进行备份和还原。这种方法使用 Cloud Storage 传输备份内容。

教程的这一部分使用您在使用 Compute Engine 磁盘快照克隆数据库部分创建的资源。如果您未完成此部分,则必须先完成,才能继续操作。

在本教程的这一部分,您将执行以下操作:

  • 创建 Cloud Storage 存储分区。
  • 备份生产服务器上的数据库。
  • 将备份文件从生产服务器复制到 Cloud Storage。
  • 将备份文件从 Cloud Storage 复制到测试服务器。
  • 在测试实例上恢复此备份。

以下图表展示如何通过使用 Cloud Storage 传输备份来克隆数据库。

展示使用 Cloud Storage 克隆 SQL Server 数据库的设置。

由于 Google Cloud 外部的系统可以获得对 Cloud Storage 的访问权限,您可以使用此方法从外部 SQL Server 实例克隆数据库。

创建 Cloud Storage 存储桶

在将备份文件从 sql-server-prod 实例传输到 sql-server-test 实例时,您需要创建一个 Cloud Storage 存储桶来存储它们。

控制台

  1. 在 Google Cloud 控制台中,转到 Cloud Storage 的浏览器页面。

    转到“Cloud Storage 浏览器”页面

  2. 点击创建存储分区

  3. 将此存储分区命名为 project-name-bucket。

    替换以下内容:

    • project-name:您的 Google Cloud 项目的 ID。
  4. 展开选择一个默认存储类别,然后选择地区级

  5. 对于位置,选择 us-east1

  6. 点击创建

Cloud Shell

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 在虚拟机实例所在的地区中创建一个 Cloud Storage 存储分区:

    gsutil mb -l "${REGION}" "gs://$(gcloud config get-value project)-bucket"
    

对数据库进行完整的时间点备份

在生产环境中,您可能已经进行了备份。您可以使用这些备份作为克隆数据库的基础。在本教程中,您制作一个仅复制备份,以免它影响任何现有或增量备份安排。

SSMS 向导

  1. 在连接到 sql-server-prod 实例的 RDP 会话中,打开 Microsoft SQL Server Management Studio,然后连接到 sql-server-prod 数据库引擎。
  2. 在 Object Explorer 中,展开 Databases,右键点击 WorldWideImporters 数据库,然后选择 Tasks > Back Up
  3. Back Up Database 向导中,确保设置了以下值:
    • Backup type 设置为 Full
    • 选中了 Copy-only backup
    • Back up to 设置为 Disk
  4. 如需添加备份文件,请点击 Add
  5. Destination 字段中,输入 D:\sql-server-data\WideWorldImporters-copy.bak

    显示备份数据库对话框的屏幕截图。

  6. 选择 Media Options 页面,然后选择 Overwrite all existing backup sets

  7. 选择 Backup Options 页面,然后将 Set backup compression 更改为 Compress backup

  8. 如需创建备份,请点击 OK

    创建备份需要几分钟。

Transact-SQL

  1. 在连接到 sql-server-prod 实例的 RDP 会话中,打开 Microsoft SQL Server Management Studio,然后连接到 sql-server-prod 数据库引擎。
  2. 如需执行 WideWorldImporters 数据库的仅复制压缩备份并存入 d:\sql-server-data\WideWorldImporters-copy.bak 文件,请将以下脚本复制到新的查询窗口中,右键点击代码,然后点击 Execute

    BACKUP DATABASE [WideWorldImporters]
       TO  DISK = N'd:\sql-server-data\WideWorldImporters-copy.bak'
       WITH  COPY_ONLY, NOFORMAT, INIT,
       NAME = N'WideWorldImporters-Full Database Backup',
       SKIP, NOREWIND, NOUNLOAD, COMPRESSION,  STATS = 10
    GO
    

    等待服务器创建备份,这可能需要几分钟。数据库备份完成后,您可以关闭查询窗口而不保存。

将备份文件复制到 Cloud Storage

  1. 在连接到 sql-server-prod 实例的 RDP 会话中,打开一个 Windows PowerShell 窗口。
  2. 将备份文件复制到您之前创建的 Cloud Storage 存储桶中:

    gsutil cp -n d:\sql-server-data\WideWorldImporters-copy.bak "gs://$(gcloud config get-value project)-bucket/"
    
  3. 退出 PowerShell。

    exit
    

将备份文件从 Cloud Storage 复制到 sql-server-test

  1. 在连接到 sql-server-test 实例的 RDP 会话中,打开一个 Windows PowerShell 窗口。
  2. 将备份文件复制到您之前创建的 Cloud Storage 存储桶中:

    gsutil cp "gs://$(gcloud config get-value project)-bucket/WideWorldImporters-copy.bak" d:\sql-server-data\
    
  3. 退出 PowerShell。

    exit
    

测试实例现在在其本地磁盘上已有数据库的完整副本备份。

恢复备份

现在,您可以将完整副本备份内容还原到 sql-server-test 实例的 D 盘 (data)。

SSMS 向导

  1. 在连接到 sql-server-test 实例的 RDP 会话中,打开 Microsoft SQL Server Management Studio,然后连接到 sql-server-test 数据库引擎。
  2. 在 Object Explorer 中,右键点击 Databases,然后选择 Restore Database
  3. 对于 Source,请选择 Device,然后点击设备名称旁边的 [...] 按钮。
  4. Select backup devices 对话框中,选择 Backup media type 列表中的 File,然后点击 Add
  5. 在文件选择器中,浏览至 D:\sql-server-data,点击 WideWorldImporters-copy.bak 文件,然后点击 OK
  6. 点击 OK 关闭 Select backup devices 对话框。

    Restore Database 对话框现在填充了有关 WideWorldImporters 数据库备份的数据。

  7. Select a page 下,点击 Files

  8. 选择 Relocate all files to folder

  9. Data file folderLog file folder 字段中,输入 D:\sql-server-data\wideworldimporters

    显示 Restore Database 对话框的屏幕截图。

  10. 如需开始恢复操作,请点击 OK

    处理完成后,您会看到以下消息:Database 'WideWorldImporters' restored successfully

Transact-SQL

  1. 在连接到 sql-server-test 实例的 RDP 会话中,打开 Microsoft SQL Server Management Studio,然后连接到 sql-server-test 数据库引擎。
  2. 选择 File > New > Query with Current Connection 以打开新的查询窗口。
  3. 复制以下 T-SQL 命令,利用您从 Cloud Storage 复制的备份文件启动恢复操作,以将数据库和日志文件恢复到 D:\sql-server-data\wideworldimporters 目录:

    USE [master]
    GO
    
    RESTORE DATABASE [WideWorldImporters]
      FROM  DISK = N'D:\SQL-SERVER-DATA\WideWorldImporters-copy.bak'
      WITH  FILE = 1,
      MOVE N'WWI_Primary' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters.mdf',
      MOVE N'WWI_UserData' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters_UserData.ndf',
      MOVE N'WWI_Log' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters.ldf',
      MOVE N'WWI_InMemory_Data_1' TO
        N'D:\SQL-SERVER-DATA\WideWorldImporters\WideWorldImporters_InMemory_Data_1',
      NOUNLOAD,
      STATS = 5
    GO
    
  4. 右键点击代码,然后点击 Execute

    几分钟后,数据库恢复即可完成。您可以在 Object Explorer 中点击 Refresh ,查看该数据库是否在数据库树中列出。数据库恢复完成后,您可以关闭查询窗口而不保存。

为表明数据库能正常运行,您可以运行一个查询。

  1. 在 Microsoft SQL Management Studio 中,选择 File > New > Query with Current Connection 以打开新的查询窗口,然后复制以下代码:

    SELECT top(100)
      i.InvoiceDate, i.InvoiceID, i.CustomerID, c.CustomerName,
      i.ConfirmedDeliveryTime, i.ConfirmedReceivedBy
    FROM
      WideWorldImporters.Sales.Invoices i
      JOIN WideWorldImporters.Sales.Customers c
      ON i.CustomerID=c.CustomerID
    WHERE i.ConfirmedDeliveryTime IS NOT NULL
    ORDER BY i.InvoiceDate desc;
    

    此查询从最近交付的 100 个账单中检索汇总信息。

  2. 右键点击查询窗口,然后点击 Execute

    Results 窗格显示摘要信息。

    显示查询示例数据库的结果空格的屏幕截图。

使用 Cloud SQL 作为克隆目标

如果您的目标数据库托管在 Cloud SQL 上,并且源数据库位于 Compute Engine 上,则唯一支持的克隆机制是将数据库备份到 Cloud Storage,然后将数据库恢复到 Cloud SQL。

在本教程中,您将重复使用在上一部分中创建的备份。

创建 Cloud SQL for SQL Server 实例

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 创建 Cloud SQL for SQL Server 实例,该实例运行的数据库版本与您的 sql-server-prod 实例相同:

    gcloud sql instances create sqlserver-cloudsql  \
      --database-version=SQLSERVER_2022_STANDARD \
      --cpu=2 \
      --memory=5GB \
      --root-password=sqlserver12@ \
      --region=${REGION}
    

    这将创建一个根用户为 sqlserver 且密码为 sqlserver12@ 的实例。

更新对象权限

您需要在 Cloud Storage 存储桶和备份对象上设置正确的权限,使 Cloud SQL 服务账号能够读取它们。这些权限是在您使用 Google Cloud 控制台导入对象时自动设置的,也可以使用 gcloud 命令设置它们。

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 设置包含 Cloud SQL 实例的服务账号地址的环境变量:

    CLOUDSQL_SA="$(gcloud sql instances describe sqlserver-cloudsql --format='get(serviceAccountEmailAddress)')"
    
  3. 将服务账号作为 writer 添加到存储桶 ACL 中,并将其作为 reader 添加到导出对象中:

    gsutil acl ch -u "${CLOUDSQL_SA}":W "gs://$(gcloud config get-value project)-bucket/"
    gsutil acl ch -u "${CLOUDSQL_SA}":R \
        "gs://$(gcloud config get-value project)-bucket/WideWorldImporters-copy.bak"
    

导入之前导出的数据库

  1. 打开 Cloud Shell。

    打开 Cloud Shell

  2. 将导出的文件导入 Cloud SQL 实例:

    gcloud sql import bak sqlserver-cloudsql \
        "gs://$(gcloud config get-value project)-bucket/WideWorldImporters-copy.bak" \
        --database WideWorldImporters
    

    出现提示时,输入 y

  3. 安装 SQL Server 工具软件包:

    sudo apt install -y mssql-tools
    

    如果您接受许可条款,请在出现提示时输入 yes

    您可以使用这些工具从 Cloud Shell 连接到 Cloud SQL,使您能够针对 Cloud SQL 实例运行查询。

  4. 将 Cloud SQL 代理连接到 SQL Server 实例:

    CONNECTION_NAME=$(gcloud sql instances describe sqlserver-cloudsql --format='value(connectionName)')
    cloud_sql_proxy -instances=${CONNECTION_NAME}=tcp:1433 &
    
  5. 如需验证克隆的数据库是否正常运行,请运行查询:

    /opt/mssql-tools/bin/sqlcmd -U sqlserver -S 127.0.0.1 -Q \
      'SELECT top(100)
        i.InvoiceDate, i.InvoiceID, i.CustomerID, LEFT(c.CustomerName,20) CustomerName,
        i.ConfirmedDeliveryTime, LEFT(i.ConfirmedReceivedBy,20) ConfirmedReceivedBy
      FROM
        WideWorldImporters.Sales.Invoices i
        JOIN WideWorldImporters.Sales.Customers c
        ON i.CustomerID=c.CustomerID
      WHERE i.ConfirmedDeliveryTime IS NOT NULL
      ORDER BY i.InvoiceDate desc;'
    

    出现提示时,输入 sqlserver 用户的 sqlserver-cloudsql 数据库服务器的密码 (sqlserver12@)。

    此查询从最近交付的 100 个账单中检索汇总信息。

    输出如下所示:

    InvoiceDate      InvoiceID   CustomerID  CustomerName         ConfirmedDeliveryTime                  ConfirmedReceivedBy
    ---------------- ----------- ----------- -------------------- -------------------------------------- --------------------
          2016-05-30       70349         581 Wingtip Toys (Munich            2016-05-31 07:05:00.0000000 Youssef Eriksson
          2016-05-30       70350         123 Tailspin Toys (Roe P            2016-05-31 07:10:00.0000000 Ella Zvirbule
          2016-05-30       70351         175 Tailspin Toys (San A            2016-05-31 07:15:00.0000000 Julio Correa
          2016-05-30       70352        1029 Veronika Necesana               2016-05-31 07:20:00.0000000 Veronika Necesana
          2016-05-30       70353        1014 Narendra Tickoo                 2016-05-31 07:25:00.0000000 Narendra Tickoo
          2016-05-30       70354         930 Shantanu Huq                    2016-05-31 07:30:00.0000000 Shantanu Huq
          2016-05-30       70355         963 Be Trang                        2016-05-31 07:35:00.0000000 Be Trang
          2016-05-30       70356         567 Wingtip Toys (Jerome            2016-05-31 07:40:00.0000000 Severins Polis
          2016-05-30       70357         510 Wingtip Toys (Grabil            2016-05-31 07:45:00.0000000 Manish Ghosh
    ...
    

清除数据

为避免因本教程中使用的资源而导致您的 Google Cloud 账号产生费用,您可以删除为本教程创建的 Google Cloud 项目。

  1. In the Google Cloud console, go to the Manage resources page.

    Go to Manage resources

  2. In the project list, select the project that you want to delete, and then click Delete.
  3. In the dialog, type the project ID, and then click Shut down to delete the project.

后续步骤