Modificação da QoS de um disco EVS
Função
Essa API é usada para alterar o IOPS ou a taxa de transferência de um disco EVS.
Restrições
O disco deve estar no estado available ou in-use. Para um disco SSD V2 de propósito geral, tanto o IOPS quanto a taxa de transferência podem ser alterados. Para um disco SSD V2 extreme, apenas o IOPS pode ser alterado. Esta API não é compatível com outros tipos de discos EVS.
Método de chamada
Para obter detalhes, consulte Chamada de APIs.
URI
PUT /v5/{project_id}/cloudvolumes/{volume_id}/qos
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 |
---|---|---|---|
qos_modify |
Sim |
ModifyVolumeQoSOption object |
O marcador de alteração de QoS do disco. |
Parâmetro |
Obrigatório |
Tipo |
Descrição |
---|---|---|---|
iops |
Sim |
Integer |
O novo IOPS máximo do disco. Este parâmetro é retornado apenas para discos SSD V2 de uso geral ou SSD V2 extremo.
NOTA:
Para saber os intervalos de IOPS de discos SSD V2 de uso geral e SSD V2 extremo, consulte a tabela dados de desempenho do EVS em Tipos de disco e desempenho. |
throughput |
Não |
Integer |
A nova taxa de transferência máxima do disco, na unidade de MiB/s. Este parâmetro é retornado apenas para discos SSD V2 de uso geral.
NOTA:
Para saber o intervalo de taxa de transferência dos discos SSD V2 de uso geral, consulte a tabela de dados de desempenho do EVS em Tipos de disco e desempenho. |
Parâmetros de resposta
Código de status: 202
Parâmetro |
Tipo |
Descrição |
---|---|---|
job_id |
String |
O ID da tarefa retornou em uma resposta normal.
NOTA:
Para consultar o status da tarefa, consulte Consulta de status da tarefa. |
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
PUT https://{endpoint}/v5/{project_id}/cloudvolumes/{volume_id}/qos { "qos_modify" : { "iops" : 10000, "throughput" : 200 } }
Exemplo de respostas
Código de status: 202
Accepted
{ "job_id" : "70a599e0-31e7-49b7-b260-868f441e862b" }
Código de status: 400
Bad Request
{ "error" : { "code" : "XXXX", "message" : "XXX" } }
Código de amostra do SDK
O código de amostra do SDK é o seguinte.
Java
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 |
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 ModifyVolumeQoSSolution { 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(); ModifyVolumeQoSRequest request = new ModifyVolumeQoSRequest(); ModifyVolumeQoSRequestBody body = new ModifyVolumeQoSRequestBody(); ModifyVolumeQoSOption qosModifybody = new ModifyVolumeQoSOption(); qosModifybody.withIops(10000) .withThroughput(200); body.withQosModify(qosModifybody); request.withBody(body); try { ModifyVolumeQoSResponse response = client.modifyVolumeQoS(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
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 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 = ModifyVolumeQoSRequest() qosModifybody = ModifyVolumeQoSOption( iops=10000, throughput=200 ) request.body = ModifyVolumeQoSRequestBody( qos_modify=qosModifybody ) response = client.modify_volume_qo_s(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
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 |
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.ModifyVolumeQoSRequest{} throughputQosModify:= int32(200) qosModifybody := &model.ModifyVolumeQoSOption{ Iops: int32(10000), Throughput: &throughputQosModify, } request.Body = &model.ModifyVolumeQoSRequestBody{ QosModify: qosModifybody, } response, err := client.ModifyVolumeQoS(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.