使用 Database Migration Service API

概览

Database Migration Service 提供了一个 REST API,用于以编程方式管理您的连接配置文件和迁移作业。REST API 由与创建和管理连接配置文件和迁移作业关联的资源定义。如需详细了解所有资源及其方法,请参阅 Database Migration Service API 参考文档

当直接向 Database Migration Service REST API 发送请求时,必须创建正确的请求形式,以经过身份验证的用户的身份授权请求,并处理返回的所有响应。本文档中的许多任务提供了使用 cURL 的 API 示例。

如需查看使用 API 的更多示例,请参阅 Database Migration Service API 参考文档中的请求页面。每个页面都有用几种编程语言调用 API 的示例以及特定于请求的浏览器,以帮助您了解格式良好的请求中包含哪些内容以及响应中应该包含哪些内容。

如果使用以下任意一种方法管理实例,您也在间接使用 Database Migration Service API:

使用这些方法(尤其是Google Cloud 控制台)的优势在于,它们可以极大地简化连接配置文件和迁移作业的管理(具体取决于您的用例)。如果刚开始使用 Database Migration Service,我们建议您先使用这些工具之一,然后再直接使用 REST API。

启用该 API

如需使用 Database Migration Service API,您需要启用它:

控制台

  1. 启用 Database Migration Service API
  2. 选择您的项目。
  3. 选择继续

gcloud

  1. 输入以下命令,以显示 Google Cloud项目的 ID:
    gcloud projects list
  2. 设置默认项目:
    gcloud config set project YOUR_PROJECT_ID
  3. 启用 Cloud SQL Admin API:
    gcloud services enable datamigration.googleapis.com

权限

您必须具有使用 Database Migration Service API 所需的权限。这些权限包括:

  • Database Migration Admin:拥有此权限,用户可以获取用于管理连接配置文件和迁移作业的所有 Database Migration Service 资源。
  • 数据库迁移 Viewer:利用此权限,用户对 Database Migration Service 中的连接配置文件和迁移作业拥有只读权限。
  • Cloud SQL 管理员:拥有此权限的用户可以在 Database Migration Service 中创建和管理 Cloud SQL 的连接配置文件和迁移作业。

Google Cloud 提供 Identity and Access Management (IAM),可让您授予对特定 Google Cloud 资源的更细化访问权限,并防止对其他资源进行不必要的访问。您可以使用 Google Cloud 控制台、API 的 IAM 方法或 Google Cloud CLI 来获取和设置 Database Migration Service 的权限。如需了解详情,请参阅授予、更改和撤消对资源的访问权限

API 示例

您可以在 Database Migration Service 文档的以下页面中查看将 Database Migration Service API 与 c网址 搭配使用的示例:

  • 使用 API 管理连接配置文件
  • 使用 API 管理迁移作业

这些页面会显示在 MySQLPostgreSQLSQL Server 的操作方法指南中。

通过文件提供 JSON 数据

使用 API 与 cURL 时,可以使用命令行提供属性值。如果使用的是敏感值(如密码或安全密钥),则在命令行中提供这些值会带来安全风险。为了提高安全性,您可以创建包含用于 API 调用的 JSON 数据的文件,并在命令行中提供该文件的路径。

如需通过文件向您的 cURL API 调用提供 JSON 数据,请执行以下操作:

  1. --data 字段创建一个文件,用单引号将所有内容括起来。

    包含大括号,但不包含单引号。

  2. 在命令行中,提供以 @ 字符开头文件路径作为 --data 参数:

    --data @<path-to-file>/<filename>

    例如,要为 Cloud SQL 源数据库创建连接配置文件,您可以创建一个名为 request.json 的文件,其中包含以下内容:

    {
      "displayName": "my Cloud SQL connection profile",
      "mysql": {
        "host": "10.11.12.13",
        "port": port-number-of-source-database,
        "username": "myusername",
        "password": "mypassword"
      }
    }
    

    然后,在命令行中使用以下 cRUL 命令:

    curl --header "Authorization: Bearer ${ACCESS_TOKEN}" \
         --header 'Content-Type: application/json' \
         --data @./request.json \
         -X POST \
         https://datamigration.googleapis.com/v1/projects/myProject/locations/myLocation/connectionProfiles?connectionProfileId=myCloudSQLconnectionprofile

处理长时间运行的 API 调用

某些 API 调用(如对象创建)可能需要一些时间才能完成。由于 API 是异步的,因此即使操作仍在进行中,调用也会立即返回。如果后续 API 调用使用新创建的对象,则必须等到第一个操作完成后才能继续。

您可以使用 Database Migration Service API 来管理操作。其中包括:

Database Migration Service 和 Google APIs Discovery Service

Google APIs Discovery Service 是一项可用于发现 Google API 的服务。例如,当使用 Google APIs Explorer 工具时,您使用的是 Discovery Service。

在 Discovery Service 中,Database Migration Service 表示为“datamigration”(例如:https://datamigration.googleapis.com/$discovery/rest?version=v1)。