Expansão da capacidade de um disco EVS
Função
Essa API é usada para expandir a capacidade de um disco de pagamento por uso ou anual/mensal.
Restrições
Se o status do disco a ser expandido estiver available, não há restrições. Se o status do disco a ser expandido estiver in-use, as restrições serão as seguintes:
-
Um disco compartilhado não pode ser expandido, o que significa que o valor de multiattach deve ser false.
-
O status do servidor ao qual o disco está conectado deve ser ACTIVE, PAUSED, SUSPENDED ou SHUTOFF.
Método de chamada
Para obter detalhes, consulte Chamada de APIs.
URI
POST /v2.1/{project_id}/cloudvolumes/{volume_id}/action
Parâmetro |
Obrigatório |
Tipo |
Descrição |
---|---|---|---|
project_id |
Sim |
String |
O ID do projeto. Para obter detalhes sobre como obter o ID de projeto, consulte Obtenção de um ID de projeto. |
volume_id |
Sim |
String |
O ID do disco. |
Parâmetros de solicitação
Parâmetro |
Obrigatório |
Tipo |
Descrição |
---|---|---|---|
X-Auth-Token |
Sim |
String |
O token do usuário. Ele pode ser obtido chamando a API do IAM usada para obter um token de usuário. O valor de X-Subject-Token no cabeçalho da resposta é o token do usuário. |
Parâmetro |
Obrigatório |
Tipo |
Descrição |
---|---|---|---|
bssParam |
Não |
BssParamForResizeVolume object |
O parâmetro estendido de pagamento por uso e faturamento anual/mensal. |
os-extend |
Sim |
OsExtend object |
O marcador de expansão de capacidade. |
Parâmetro |
Obrigatório |
Tipo |
Descrição |
---|---|---|---|
isAutoPay |
Não |
String |
Se deve pagar imediatamente. Este parâmetro é válido quando o disco é cobrado anualmente/mensalmente. O valor padrão é false. Valores:
Padrão: false Valores de enumeração:
|
Parâmetro |
Obrigatório |
Tipo |
Descrição |
---|---|---|---|
new_size |
Sim |
Integer |
O novo tamanho do disco, em GiB. Esse valor de parâmetro deve ser maior que o tamanho original do disco e menor que o tamanho máximo permitido para um disco. O tamanho máximo do disco:
|
Parâmetros de resposta
Código de status: 202
Parâmetro |
Tipo |
Descrição |
---|---|---|
job_id |
String |
O ID da tarefa. Esse parâmetro é retornado quando o disco é cobrado com base no pagamento por uso.
NOTA:
Para consultar o status da tarefa, consulte Consulta de status da tarefa. |
order_id |
String |
O ID do pedido. Este parâmetro é retornado quando o disco é cobrado anualmente/mensalmente.
NOTA:
Se você precisar pagar pelo pedido, consulte Pagamento de pedidos anuais/mensais de produtos. |
Código de status: 400
Parâmetro |
Tipo |
Descrição |
---|---|---|
error |
Error object |
A mensagem de erro retornada se ocorrer um erro. Para obter detalhes, consulte Parâmetros no campo error. |
Parâmetro |
Tipo |
Descrição |
---|---|---|
code |
String |
O código de erro retornado se ocorrer um erro. Para os códigos de erro e seus significados, consulte Códigos de erro. |
message |
String |
A mensagem de erro retornada se ocorrer um erro. |
Exemplo de solicitações
Expandir a capacidade de um disco EVS (Defina o tamanho do disco para 100 GiB. Você será cobrado pela expansão imediatamente.)
POST https://{endpoint}/v2.1/{project_id}/cloudvolumes/{volume_id}/action { "os-extend" : { "new_size" : 100 }, "bssParam" : { "isAutoPay" : "true" } }
Exemplo de respostas
Código de status: 202
Accepted
{ "job_id" : "70a599e0-31e7-49b7-b260-868f441e862b" }
Código de status: 400
Bad Request
{ "error" : { "message" : "XXXX", "code" : "XXX" } }
Código de amostra do SDK
O código de amostra do SDK é o seguinte.
Java
Expandir a capacidade de um disco EVS (Defina o tamanho do disco para 100 GiB. Você será cobrado pela expansão imediatamente.)
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 53 |
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.evs.v2.region.EvsRegion; import com.huaweicloud.sdk.evs.v2.*; import com.huaweicloud.sdk.evs.v2.model.*; public class ResizeVolumeSolution { 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"); ICredential auth = new BasicCredentials() .withAk(ak) .withSk(sk); EvsClient client = EvsClient.newBuilder() .withCredential(auth) .withRegion(EvsRegion.valueOf("<YOUR REGION>")) .build(); ResizeVolumeRequest request = new ResizeVolumeRequest(); ResizeVolumeRequestBody body = new ResizeVolumeRequestBody(); OsExtend osextendbody = new OsExtend(); osextendbody.withNewSize(100); BssParamForResizeVolume bssParambody = new BssParamForResizeVolume(); bssParambody.withIsAutoPay(BssParamForResizeVolume.IsAutoPayEnum.fromValue("true")); body.withOsExtend(osextendbody); body.withBssParam(bssParambody); request.withBody(body); try { ResizeVolumeResponse response = client.resizeVolume(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()); } } } |
Python
Expandir a capacidade de um disco EVS (Defina o tamanho do disco para 100 GiB. Você será cobrado pela expansão imediatamente.)
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 |
# coding: utf-8 from huaweicloudsdkcore.auth.credentials import BasicCredentials from huaweicloudsdkevs.v2.region.evs_region import EvsRegion from huaweicloudsdkcore.exceptions import exceptions from huaweicloudsdkevs.v2 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 = __import__('os').getenv("CLOUD_SDK_AK") sk = __import__('os').getenv("CLOUD_SDK_SK") credentials = BasicCredentials(ak, sk) \ client = EvsClient.new_builder() \ .with_credentials(credentials) \ .with_region(EvsRegion.value_of("<YOUR REGION>")) \ .build() try: request = ResizeVolumeRequest() osextendbody = OsExtend( new_size=100 ) bssParambody = BssParamForResizeVolume( is_auto_pay="true" ) request.body = ResizeVolumeRequestBody( os_extend=osextendbody, bss_param=bssParambody ) response = client.resize_volume(request) print(response) except exceptions.ClientRequestException as e: print(e.status_code) print(e.request_id) print(e.error_code) print(e.error_msg) |
Go
Expandir a capacidade de um disco EVS (Defina o tamanho do disco para 100 GiB. Você será cobrado pela expansão imediatamente.)
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 |
package main import ( "fmt" "github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic" evs "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/evs/v2" "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/evs/v2/model" region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/evs/v2/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") auth := basic.NewCredentialsBuilder(). WithAk(ak). WithSk(sk). Build() client := evs.NewEvsClient( evs.EvsClientBuilder(). WithRegion(region.ValueOf("<YOUR REGION>")). WithCredential(auth). Build()) request := &model.ResizeVolumeRequest{} osextendbody := &model.OsExtend{ NewSize: int32(100), } isAutoPayBssParam:= model.GetBssParamForResizeVolumeIsAutoPayEnum().TRUE bssParambody := &model.BssParamForResizeVolume{ IsAutoPay: &isAutoPayBssParam, } request.Body = &model.ResizeVolumeRequestBody{ OsExtend: osextendbody, BssParam: bssParambody, } response, err := client.ResizeVolume(request) if err == nil { fmt.Printf("%+v\n", response) } else { fmt.Println(err) } } |
Mais
Para obter o código de amostra do SDK de mais linguagens de programação, consulte a guia Código de amostra no API Explorer. O código de amostra do SDK pode ser gerado automaticamente.
Códigos de status
Código de status |
Descrição |
---|---|
202 |
Accepted |
400 |
Bad Request |
Códigos de erro
Consulte Códigos de erro.