文档首页/ 云数据库 TaurusDB/ API参考/ API(推荐)/ 实例管理/ 设置Serverless算力策略 - UpdateServerlessComputeAbilityPolicy
更新时间:2025-10-16 GMT+08:00
分享

设置Serverless算力策略 - UpdateServerlessComputeAbilityPolicy

功能介绍

设置Serverless算力策略。

调用方法

请参见如何调用API

授权信息

账号具备所有API的调用权限,如果使用账号下的IAM用户调用当前API,该IAM用户需具备调用API所需的权限。

  • 如果使用角色与策略授权,具体权限要求请参见权限和授权项
  • 如果使用身份策略授权,需具备如下身份策略权限。

    授权项

    访问级别

    资源类型(*为必须)

    条件键

    别名

    依赖的授权项

    gaussdbformysql:serverless:updateComputeAbilityPolicy

    Write

    instance *

    • g:EnterpriseProjectId

    • g:ResourceTag/<tag-key>

    • gaussdb:serverless:updateComputeAbilityPolicy

    -

URI

PUT /v3.1/{project_id}/instances/{instance_id}/serverless/policy

表1 路径参数

参数

是否必选

参数类型

描述

project_id

String

参数解释

租户在某一Region下的project ID。

获取方法请参见获取项目ID

约束限制

不涉及。

取值范围

只能由英文字母、数字组成,且长度为32个字符。

默认取值

不涉及。

instance_id

String

参数解释

实例ID,此参数是实例的唯一标识。

约束限制

不涉及。

取值范围

只能由英文字母、数字组成,后缀为in07,长度为36个字符。

默认取值

不涉及。

请求参数

表2 请求Header参数

参数

是否必选

参数类型

描述

X-Auth-Token

String

参数解释

用户Token。 通过调用IAM服务获取用户Token接口获取。

请求响应成功后在响应消息头中包含的“X-Subject-Token”的值即为Token值。

约束限制

不涉及。

取值范围

不涉及。

默认取值

不涉及。

Content-Type

String

参数解释

内容类型。

约束限制

不涉及。

取值范围

application/json。

默认取值

application/json。

X-Language

String

参数解释

请求语言类型。

约束限制

不涉及。

取值范围

  • en-us

  • zh-cn

默认取值

en-us。

表3 请求Body参数

参数

是否必选

参数类型

描述

min_vcpus

Integer

参数解释

单节点VCPUs伸缩下限。

约束限制

不涉及。

取值范围

取值范围可根据查询数据库规格接口获取。

默认取值

不涉及。

max_vcpus

Integer

参数解释

单节点VCPUs伸缩上限。

约束限制

不涉及。

取值范围

≥4。取值范围可根据查询数据库规格接口获取。

默认取值

不涉及。

need_update_nodes_compute_ability

Boolean

参数解释

节点算力同步,修改算力范围的同时,是否将小于最小算力的节点的当前算力同步至最小算力。

约束限制

不涉及。

取值范围

  • true: 节点算力同步。

  • false: 节点算力不同步。

默认取值

false。

scale_out_switch

Boolean

参数解释

是否增删只读节点。

约束限制

  • 存在数据库代理时,才可以使用增删只读节点功能。

  • 使用增删节点功能时,避免使用读内网地址连接应用。

  • 打开增删只读节点后,数据库代理的路由模式会变为负载均衡模式。

取值范围

  • true: 开启增删只读节点。

  • false: 不开启增删只读节点。

默认取值

false。

max_readonly_node_count

Integer

参数解释

只读节点数量上限。

约束限制

开启增删只读节点时才会生效, 且开启增删只读节点时该参数必选。

取值范围

2-7。

默认取值

不涉及。

min_readonly_node_count

Integer

参数解释

只读节点数量下限。

约束限制

开启增删只读节点时才会生效, 且开启增删只读节点时该参数必选。

取值范围

1-6。

默认取值

不涉及。

响应参数

状态码:200

Success.

状态码:400

表4 响应Body参数

参数

参数类型

描述

error_code

String

错误码。

error_msg

String

错误消息。

状态码:500

表5 响应Body参数

参数

参数类型

描述

error_code

String

错误码。

error_msg

String

错误消息。

请求示例

设置VCPUs伸缩下限为0.5,设置VCPUs伸缩上限为4。

PUT https://{endpoint}/v3.1/054e292c9880d4992f02c0196d3ea468/instances/096c0fc43e804757b59946b80dc27f8bin07/serverless/policy

{
  "min_vcpus" : 0.5,
  "max_vcpus" : 4
}

响应示例

SDK代码示例

SDK代码示例如下。

设置VCPUs伸缩下限为0.5,设置VCPUs伸缩上限为4。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package com.huaweicloud.sdk.test;

import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.BasicCredentials;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.gaussdb.v3.region.GaussDBRegion;
import com.huaweicloud.sdk.gaussdb.v3.*;
import com.huaweicloud.sdk.gaussdb.v3.model.*;


public class UpdateServerlessComputeAbilityPolicySolution {

    public static void main(String[] args) {
        // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
        // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
        String ak = System.getenv("CLOUD_SDK_AK");
        String sk = System.getenv("CLOUD_SDK_SK");
        String projectId = "{project_id}";

        ICredential auth = new BasicCredentials()
                .withProjectId(projectId)
                .withAk(ak)
                .withSk(sk);

        GaussDBClient client = GaussDBClient.newBuilder()
                .withCredential(auth)
                .withRegion(GaussDBRegion.valueOf("<YOUR REGION>"))
                .build();
        UpdateServerlessComputeAbilityPolicyRequest request = new UpdateServerlessComputeAbilityPolicyRequest();
        request.withInstanceId("{instance_id}");
        UpdateServerlessComputeAbilityPolicy body = new UpdateServerlessComputeAbilityPolicy();
        body.withMaxVcpus(4);
        body.withMinVcpus(0.5);
        request.withBody(body);
        try {
            UpdateServerlessComputeAbilityPolicyResponse response = client.updateServerlessComputeAbilityPolicy(request);
            System.out.println(response.toString());
        } catch (ConnectionException e) {
            e.printStackTrace();
        } catch (RequestTimeoutException e) {
            e.printStackTrace();
        } catch (ServiceResponseException e) {
            e.printStackTrace();
            System.out.println(e.getHttpStatusCode());
            System.out.println(e.getRequestId());
            System.out.println(e.getErrorCode());
            System.out.println(e.getErrorMsg());
        }
    }
}

设置VCPUs伸缩下限为0.5,设置VCPUs伸缩上限为4。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# coding: utf-8

import os
from huaweicloudsdkcore.auth.credentials import BasicCredentials
from huaweicloudsdkgaussdb.v3.region.gaussdb_region import GaussDBRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkgaussdb.v3 import *

if __name__ == "__main__":
    # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak = os.environ["CLOUD_SDK_AK"]
    sk = os.environ["CLOUD_SDK_SK"]
    projectId = "{project_id}"

    credentials = BasicCredentials(ak, sk, projectId)

    client = GaussDBClient.new_builder() \
        .with_credentials(credentials) \
        .with_region(GaussDBRegion.value_of("<YOUR REGION>")) \
        .build()

    try:
        request = UpdateServerlessComputeAbilityPolicyRequest()
        request.instance_id = "{instance_id}"
        request.body = UpdateServerlessComputeAbilityPolicy(
            max_vcpus=4,
            min_vcpus=0.5
        )
        response = client.update_serverless_compute_ability_policy(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)

设置VCPUs伸缩下限为0.5,设置VCPUs伸缩上限为4。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic"
    gaussdb "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/gaussdb/v3"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/gaussdb/v3/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/gaussdb/v3/region"
)

func main() {
    // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak := os.Getenv("CLOUD_SDK_AK")
    sk := os.Getenv("CLOUD_SDK_SK")
    projectId := "{project_id}"

    auth := basic.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        WithProjectId(projectId).
        Build()

    client := gaussdb.NewGaussDBClient(
        gaussdb.GaussDBClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.UpdateServerlessComputeAbilityPolicyRequest{}
	request.InstanceId = "{instance_id}"
	request.Body = &model.UpdateServerlessComputeAbilityPolicy{
		MaxVcpus: int32(4),
		MinVcpus: int32(0.5),
	}
	response, err := client.UpdateServerlessComputeAbilityPolicy(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

更多编程语言的SDK代码示例,请参见API Explorer的代码示例页签,可生成自动对应的SDK代码示例。

状态码

状态码

描述

200

Success.

400

Client error.

500

Server error.

错误码

请参见错误码

相关文档