我想通过 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)
要更新 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 > 编辑中查看新实例信息:
| 归档时间: |
|
| 查看次数: |
4771 次 |
| 最近记录: |