我可以通过 API 或以编程方式更改 Cloud SQL 实例的 CPU 和内存数量吗?

Hei*_*ang 4 google-cloud-sql

我想通过 API 将 PostgreSQL 实例的 CPU 和内存数量编辑为自定义值,例如每个 2 个 vCPU 和 5 GB 内存,但尚未找到实现此目的的方法。

实例设置页面将核心和内存显示为选项,但是当我尝试使用此处给出的curl示例设置简单的JSON时,

{
  "settings": {
    "cores": 2,
    "memory": 5
  }
}
Run Code Online (Sandbox Code Playgroud)

什么都没发生。

我找到了一种获取现有设置的方法,通过curl -X GET -H "Authorization: Bearer "$(gcloud auth print-access-token) -H "Content-Type: application/json; charset=utf-8" "https://sqladmin.googleapis.com/v1/projects/MYPROJECT/instances/MYINSTANCE"

返回的 JSON 有dataDiskSizeGb,但与 CPU 或内存无关,这对我来说是显而易见的。

{
  "kind": "sql#instance",
  "state": "RUNNABLE",
  "databaseVersion": "POSTGRES_12",
  "settings": {
    "authorizedGaeApplications": [],
    "tier": "db-custom-1-3840",
    "kind": "sql#settings",
    "availabilityType": "ZONAL",
    "pricingPlan": "PER_USE",
    "replicationType": "SYNCHRONOUS",
    "activationPolicy": "ALWAYS",
    "ipConfiguration": {
      "privateNetwork": "projects/MYPROJECT/global/networks/default",
      "authorizedNetworks": [],
      "ipv4Enabled": true
    },
    "locationPreference": {
      "zone": "southamerica-east1-c",
      "kind": "sql#locationPreference"
    },
    "dataDiskType": "PD_SSD",
    "maintenanceWindow": {
      "kind": "sql#maintenanceWindow",
      "hour": 0,
      "day": 0
    },
    "backupConfiguration": {
      "startTime": "08:00",
      "kind": "sql#backupConfiguration",
      "location": "us",
      "backupRetentionSettings": {
        "retentionUnit": "COUNT",
        "retainedBackups": 7
      },
      "enabled": true,
      "replicationLogArchivingEnabled": false,
      "pointInTimeRecoveryEnabled": false,
      "transactionLogRetentionDays": 7
    },
    "settingsVersion": "4",
    "storageAutoResizeLimit": "0",
    "storageAutoResize": false,
    "dataDiskSizeGb": "10"
  },
  "etag": "079...039",
  "ipAddresses": [
    {
      "type": "PRIMARY",
      "ipAddress": "xx.xxx.x.xxx"
    },
    {
      "type": "OUTGOING",
      "ipAddress": "xx.xx.xxx.xx"
    },
    {
      "type": "PRIVATE",
      "ipAddress": "xx.xx.xxx.xx"
    }
  ],
  "serverCaCert": {
    "kind": "sql#sslCert",
    "certSerialNumber": "0",
    "cert": "-----BEGIN CERTIFICATE-----\nMII......c=\n-----END CERTIFICATE-----",
    "commonName": "C=US,O=Google\\, Inc,CN=Google Cloud SQL Server CA,dnQualifier=9f7...e0c",
    "sha1Fingerprint": "fff...8fb",
    "instance": "MYINSTANCE",
    "createTime": "2021-10-05T17:59:18.971Z",
    "expirationTime": "2031-10-03T18:00:18.971Z"
  },
  "instanceType": "CLOUD_SQL_INSTANCE",
  "project": "MYPROJECT",
  "serviceAccountEmailAddress": "abc...@gcp-sa-cloud-sql.iam.gserviceaccount.com",
  "backendType": "SECOND_GEN",
  "selfLink": "https://sqladmin.googleapis.com/v1/projects/MYPROJECT/instances/MYINSTANCE",
  "connectionName": "MYPROJECT:southamerica-east1:MYINSTANCE",
  "name": "MYINSTANCE",
  "region": "southamerica-east1",
  "gceZone": "southamerica-east1-c",
  "createTime": "2021-10-05T17:57:47.539Z"
}
Run Code Online (Sandbox Code Playgroud)

Ric*_*o D 6

要更新 CPU 和内存的数量,在“设置”REST 参考上 有一个"tier"表示实例的 CPU 和内存的字段。在您的示例中"db-custom-1-3840",这些值代表 CPU 和内存 ( db-custom-[CPU]-[Memory] ​​),这意味着它有 1 个 CPU 和 3840 内存。要将计算机更改为 2vCPU 和 5GB 内存,"tier"其值应为"db-custom-2-5120"

出于测试目的,我最初创建了一个具有 26 GB 内存的 4 个 vCPU。有关参考,请参阅初始实例配置:

在此输入图像描述

要更改 CPU 和内存,请参阅以下步骤:

请求.json:

{
  "settings": {
    "tier":  "db-custom-2-5120"
  }
}
Run Code Online (Sandbox Code Playgroud)

注意:内存的值应为 256MB 的倍数,因此值为 5120。

卷曲命令:

curl -X PATCH \
-H "Authorization: Bearer "$(gcloud auth print-access-token) \
-H "Content-Type: application/json; charset=utf-8" \
-d @request.json \
"https://sqladmin.googleapis.com/v1/projects/your-project-name/instances/your-instance-name"
Run Code Online (Sandbox Code Playgroud)

这将返回一个长时间运行的操作:

在此输入图像描述

当我运行时,GET curl -X GET -H "Content-Type: application/json" -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) https://sqladmin.googleapis.com/v1/projects/your-project-name/instances/your-instance-name更改就会反映出来。

请参阅 GET 响应片段:

在此输入图像描述

在 Cloud Console > SQL > 编辑中查看新实例信息:

在此输入图像描述