Updated on 2024-07-08 GMT+08:00

Managing Migration Tasks

Function

This API is used for managing migration tasks, including starting, pausing, and synchronizing tasks, uploading logs, and rolling back failed migration tasks.

Calling Method

For details, see Calling APIs.

URI

POST /v3/tasks/{task_id}/action

Table 1 Path parameter

Parameter

Mandatory

Type

Description

task_id

Yes

String

The migration task ID.

Minimum length: 0 characters

Maximum length: 255 characters

Request

Table 2 Request header parameter

Parameter

Mandatory

Type

Description

X-Auth-Token

Yes

String

The user token. It can be obtained by calling the IAM API (value of X-Subject-Token in the response header).

Minimum length: 1 character

Maximum length: 16,384 characters

Table 3 Request body parameters

Parameter

Mandatory

Type

Description

operation

Yes

String

The operation to be performed on the task.

The value can be:

  • start

  • stop

  • collect_log

  • test

  • clone_test

  • restart

  • sync_failed_rollback

param

No

Map<String,String>

The operation parameters.

switch_hce

No

Boolean

Indicates whether to change to Huawei Cloud EulerOS.

Default value: false

is_need_consistency_check

No

Boolean

Whether consistency verification is enabled.

Default value: false

Response

None

Example Request

  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

    POST https://{endpoint}/v3/tasks/7a9a9540-ff28-4869-b9e4-855fbe12xxxx/action
    
    {
      "operation" : "clone_test"
    }
  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

    POST https://{endpoint}/v3/tasks/7a9a9540-ff28-4869-b9e4-855fbe12xxxx/action
    
    {
      "operation" : "test"
    }
  • This example starts the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

    POST https://{endpoint}/v3/tasks/7a9a9540-ff28-4869-b9e4-855fbe12xxxx/action
    
    {
      "operation" : "start"
    }
  • This example rolls back the failed synchronization task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

    POST https://{endpoint}/v3/tasks/7a9a9540-ff28-4869-b9e4-855fbe12xxxx/action
    
    {
      "operation" : "sync_failed_rollback"
    }
  • This example pauses the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

    POST https://{endpoint}/v3/tasks/7a9a9540-ff28-4869-b9e4-855fbe12xxxx/action
    
    {
      "operation" : "stop"
    }
  • This example restarts the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

    POST https://{endpoint}/v3/tasks/7a9a9540-ff28-4869-b9e4-855fbe12xxxx/action
    
    {
      "operation" : "restart"
    }
  • This example uploads the logs of the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

    POST https://{endpoint}/v3/tasks/7a9a9540-ff28-4869-b9e4-855fbe12xxxx/action
    
    {
      "operation" : "collect_log"
    }

Example Response

None

SDK Sample Code

The sample code is as follows.

  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package com.huaweicloud.sdk.test;
    
    import com.huaweicloud.sdk.core.auth.ICredential;
    import com.huaweicloud.sdk.core.auth.GlobalCredentials;
    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.sms.v3.region.SmsRegion;
    import com.huaweicloud.sdk.sms.v3.*;
    import com.huaweicloud.sdk.sms.v3.model.*;
    
    
    public class UpdateTaskStatusSolution {
    
        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 GlobalCredentials()
                    .withAk(ak)
                    .withSk(sk);
    
            SmsClient client = SmsClient.newBuilder()
                    .withCredential(auth)
                    .withRegion(SmsRegion.valueOf("<YOUR REGION>"))
                    .build();
            UpdateTaskStatusRequest request = new UpdateTaskStatusRequest();
            UpdateTaskStatusReq body = new UpdateTaskStatusReq();
            body.withOperation(UpdateTaskStatusReq.OperationEnum.fromValue("clone_test"));
            request.withBody(body);
            try {
                UpdateTaskStatusResponse response = client.updateTaskStatus(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());
            }
        }
    }
    
  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package com.huaweicloud.sdk.test;
    
    import com.huaweicloud.sdk.core.auth.ICredential;
    import com.huaweicloud.sdk.core.auth.GlobalCredentials;
    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.sms.v3.region.SmsRegion;
    import com.huaweicloud.sdk.sms.v3.*;
    import com.huaweicloud.sdk.sms.v3.model.*;
    
    
    public class UpdateTaskStatusSolution {
    
        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 GlobalCredentials()
                    .withAk(ak)
                    .withSk(sk);
    
            SmsClient client = SmsClient.newBuilder()
                    .withCredential(auth)
                    .withRegion(SmsRegion.valueOf("<YOUR REGION>"))
                    .build();
            UpdateTaskStatusRequest request = new UpdateTaskStatusRequest();
            UpdateTaskStatusReq body = new UpdateTaskStatusReq();
            body.withOperation(UpdateTaskStatusReq.OperationEnum.fromValue("test"));
            request.withBody(body);
            try {
                UpdateTaskStatusResponse response = client.updateTaskStatus(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());
            }
        }
    }
    
  • This example starts the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package com.huaweicloud.sdk.test;
    
    import com.huaweicloud.sdk.core.auth.ICredential;
    import com.huaweicloud.sdk.core.auth.GlobalCredentials;
    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.sms.v3.region.SmsRegion;
    import com.huaweicloud.sdk.sms.v3.*;
    import com.huaweicloud.sdk.sms.v3.model.*;
    
    
    public class UpdateTaskStatusSolution {
    
        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 GlobalCredentials()
                    .withAk(ak)
                    .withSk(sk);
    
            SmsClient client = SmsClient.newBuilder()
                    .withCredential(auth)
                    .withRegion(SmsRegion.valueOf("<YOUR REGION>"))
                    .build();
            UpdateTaskStatusRequest request = new UpdateTaskStatusRequest();
            UpdateTaskStatusReq body = new UpdateTaskStatusReq();
            body.withOperation(UpdateTaskStatusReq.OperationEnum.fromValue("start"));
            request.withBody(body);
            try {
                UpdateTaskStatusResponse response = client.updateTaskStatus(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());
            }
        }
    }
    
  • This example rolls back the failed synchronization task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package com.huaweicloud.sdk.test;
    
    import com.huaweicloud.sdk.core.auth.ICredential;
    import com.huaweicloud.sdk.core.auth.GlobalCredentials;
    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.sms.v3.region.SmsRegion;
    import com.huaweicloud.sdk.sms.v3.*;
    import com.huaweicloud.sdk.sms.v3.model.*;
    
    
    public class UpdateTaskStatusSolution {
    
        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 GlobalCredentials()
                    .withAk(ak)
                    .withSk(sk);
    
            SmsClient client = SmsClient.newBuilder()
                    .withCredential(auth)
                    .withRegion(SmsRegion.valueOf("<YOUR REGION>"))
                    .build();
            UpdateTaskStatusRequest request = new UpdateTaskStatusRequest();
            UpdateTaskStatusReq body = new UpdateTaskStatusReq();
            body.withOperation(UpdateTaskStatusReq.OperationEnum.fromValue("sync_failed_rollback"));
            request.withBody(body);
            try {
                UpdateTaskStatusResponse response = client.updateTaskStatus(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());
            }
        }
    }
    
  • This example pauses the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package com.huaweicloud.sdk.test;
    
    import com.huaweicloud.sdk.core.auth.ICredential;
    import com.huaweicloud.sdk.core.auth.GlobalCredentials;
    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.sms.v3.region.SmsRegion;
    import com.huaweicloud.sdk.sms.v3.*;
    import com.huaweicloud.sdk.sms.v3.model.*;
    
    
    public class UpdateTaskStatusSolution {
    
        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 GlobalCredentials()
                    .withAk(ak)
                    .withSk(sk);
    
            SmsClient client = SmsClient.newBuilder()
                    .withCredential(auth)
                    .withRegion(SmsRegion.valueOf("<YOUR REGION>"))
                    .build();
            UpdateTaskStatusRequest request = new UpdateTaskStatusRequest();
            UpdateTaskStatusReq body = new UpdateTaskStatusReq();
            body.withOperation(UpdateTaskStatusReq.OperationEnum.fromValue("stop"));
            request.withBody(body);
            try {
                UpdateTaskStatusResponse response = client.updateTaskStatus(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());
            }
        }
    }
    
  • This example restarts the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package com.huaweicloud.sdk.test;
    
    import com.huaweicloud.sdk.core.auth.ICredential;
    import com.huaweicloud.sdk.core.auth.GlobalCredentials;
    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.sms.v3.region.SmsRegion;
    import com.huaweicloud.sdk.sms.v3.*;
    import com.huaweicloud.sdk.sms.v3.model.*;
    
    
    public class UpdateTaskStatusSolution {
    
        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 GlobalCredentials()
                    .withAk(ak)
                    .withSk(sk);
    
            SmsClient client = SmsClient.newBuilder()
                    .withCredential(auth)
                    .withRegion(SmsRegion.valueOf("<YOUR REGION>"))
                    .build();
            UpdateTaskStatusRequest request = new UpdateTaskStatusRequest();
            UpdateTaskStatusReq body = new UpdateTaskStatusReq();
            body.withOperation(UpdateTaskStatusReq.OperationEnum.fromValue("restart"));
            request.withBody(body);
            try {
                UpdateTaskStatusResponse response = client.updateTaskStatus(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());
            }
        }
    }
    
  • This example uploads the logs of the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package com.huaweicloud.sdk.test;
    
    import com.huaweicloud.sdk.core.auth.ICredential;
    import com.huaweicloud.sdk.core.auth.GlobalCredentials;
    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.sms.v3.region.SmsRegion;
    import com.huaweicloud.sdk.sms.v3.*;
    import com.huaweicloud.sdk.sms.v3.model.*;
    
    
    public class UpdateTaskStatusSolution {
    
        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 GlobalCredentials()
                    .withAk(ak)
                    .withSk(sk);
    
            SmsClient client = SmsClient.newBuilder()
                    .withCredential(auth)
                    .withRegion(SmsRegion.valueOf("<YOUR REGION>"))
                    .build();
            UpdateTaskStatusRequest request = new UpdateTaskStatusRequest();
            UpdateTaskStatusReq body = new UpdateTaskStatusReq();
            body.withOperation(UpdateTaskStatusReq.OperationEnum.fromValue("collect_log"));
            request.withBody(body);
            try {
                UpdateTaskStatusResponse response = client.updateTaskStatus(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());
            }
        }
    }
    
  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    # coding: utf-8
    
    import os
    from huaweicloudsdkcore.auth.credentials import GlobalCredentials
    from huaweicloudsdksms.v3.region.sms_region import SmsRegion
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdksms.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"]
    
        credentials = GlobalCredentials(ak, sk)
    
        client = SmsClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(SmsRegion.value_of("<YOUR REGION>")) \
            .build()
    
        try:
            request = UpdateTaskStatusRequest()
            request.body = UpdateTaskStatusReq(
                operation="clone_test"
            )
            response = client.update_task_status(request)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    # coding: utf-8
    
    import os
    from huaweicloudsdkcore.auth.credentials import GlobalCredentials
    from huaweicloudsdksms.v3.region.sms_region import SmsRegion
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdksms.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"]
    
        credentials = GlobalCredentials(ak, sk)
    
        client = SmsClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(SmsRegion.value_of("<YOUR REGION>")) \
            .build()
    
        try:
            request = UpdateTaskStatusRequest()
            request.body = UpdateTaskStatusReq(
                operation="test"
            )
            response = client.update_task_status(request)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  • This example starts the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    # coding: utf-8
    
    import os
    from huaweicloudsdkcore.auth.credentials import GlobalCredentials
    from huaweicloudsdksms.v3.region.sms_region import SmsRegion
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdksms.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"]
    
        credentials = GlobalCredentials(ak, sk)
    
        client = SmsClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(SmsRegion.value_of("<YOUR REGION>")) \
            .build()
    
        try:
            request = UpdateTaskStatusRequest()
            request.body = UpdateTaskStatusReq(
                operation="start"
            )
            response = client.update_task_status(request)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  • This example rolls back the failed synchronization task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    # coding: utf-8
    
    import os
    from huaweicloudsdkcore.auth.credentials import GlobalCredentials
    from huaweicloudsdksms.v3.region.sms_region import SmsRegion
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdksms.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"]
    
        credentials = GlobalCredentials(ak, sk)
    
        client = SmsClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(SmsRegion.value_of("<YOUR REGION>")) \
            .build()
    
        try:
            request = UpdateTaskStatusRequest()
            request.body = UpdateTaskStatusReq(
                operation="sync_failed_rollback"
            )
            response = client.update_task_status(request)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  • This example pauses the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    # coding: utf-8
    
    import os
    from huaweicloudsdkcore.auth.credentials import GlobalCredentials
    from huaweicloudsdksms.v3.region.sms_region import SmsRegion
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdksms.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"]
    
        credentials = GlobalCredentials(ak, sk)
    
        client = SmsClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(SmsRegion.value_of("<YOUR REGION>")) \
            .build()
    
        try:
            request = UpdateTaskStatusRequest()
            request.body = UpdateTaskStatusReq(
                operation="stop"
            )
            response = client.update_task_status(request)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  • This example restarts the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    # coding: utf-8
    
    import os
    from huaweicloudsdkcore.auth.credentials import GlobalCredentials
    from huaweicloudsdksms.v3.region.sms_region import SmsRegion
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdksms.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"]
    
        credentials = GlobalCredentials(ak, sk)
    
        client = SmsClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(SmsRegion.value_of("<YOUR REGION>")) \
            .build()
    
        try:
            request = UpdateTaskStatusRequest()
            request.body = UpdateTaskStatusReq(
                operation="restart"
            )
            response = client.update_task_status(request)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  • This example uploads the logs of the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    # coding: utf-8
    
    import os
    from huaweicloudsdkcore.auth.credentials import GlobalCredentials
    from huaweicloudsdksms.v3.region.sms_region import SmsRegion
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdksms.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"]
    
        credentials = GlobalCredentials(ak, sk)
    
        client = SmsClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(SmsRegion.value_of("<YOUR REGION>")) \
            .build()
    
        try:
            request = UpdateTaskStatusRequest()
            request.body = UpdateTaskStatusReq(
                operation="collect_log"
            )
            response = client.update_task_status(request)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package main
    
    import (
    	"fmt"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
        sms "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3/model"
        region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/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")
    
        auth := global.NewCredentialsBuilder().
            WithAk(ak).
            WithSk(sk).
            Build()
    
        client := sms.NewSmsClient(
            sms.SmsClientBuilder().
                WithRegion(region.ValueOf("<YOUR REGION>")).
                WithCredential(auth).
                Build())
    
        request := &model.UpdateTaskStatusRequest{}
    	request.Body = &model.UpdateTaskStatusReq{
    		Operation: model.GetUpdateTaskStatusReqOperationEnum().CLONE_TEST,
    	}
    	response, err := client.UpdateTaskStatus(request)
    	if err == nil {
            fmt.Printf("%+v\n", response)
        } else {
            fmt.Println(err)
        }
    }
    
  • This example clones the target server in the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package main
    
    import (
    	"fmt"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
        sms "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3/model"
        region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/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")
    
        auth := global.NewCredentialsBuilder().
            WithAk(ak).
            WithSk(sk).
            Build()
    
        client := sms.NewSmsClient(
            sms.SmsClientBuilder().
                WithRegion(region.ValueOf("<YOUR REGION>")).
                WithCredential(auth).
                Build())
    
        request := &model.UpdateTaskStatusRequest{}
    	request.Body = &model.UpdateTaskStatusReq{
    		Operation: model.GetUpdateTaskStatusReqOperationEnum().TEST,
    	}
    	response, err := client.UpdateTaskStatus(request)
    	if err == nil {
            fmt.Printf("%+v\n", response)
        } else {
            fmt.Println(err)
        }
    }
    
  • This example starts the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package main
    
    import (
    	"fmt"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
        sms "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3/model"
        region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/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")
    
        auth := global.NewCredentialsBuilder().
            WithAk(ak).
            WithSk(sk).
            Build()
    
        client := sms.NewSmsClient(
            sms.SmsClientBuilder().
                WithRegion(region.ValueOf("<YOUR REGION>")).
                WithCredential(auth).
                Build())
    
        request := &model.UpdateTaskStatusRequest{}
    	request.Body = &model.UpdateTaskStatusReq{
    		Operation: model.GetUpdateTaskStatusReqOperationEnum().START,
    	}
    	response, err := client.UpdateTaskStatus(request)
    	if err == nil {
            fmt.Printf("%+v\n", response)
        } else {
            fmt.Println(err)
        }
    }
    
  • This example rolls back the failed synchronization task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package main
    
    import (
    	"fmt"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
        sms "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3/model"
        region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/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")
    
        auth := global.NewCredentialsBuilder().
            WithAk(ak).
            WithSk(sk).
            Build()
    
        client := sms.NewSmsClient(
            sms.SmsClientBuilder().
                WithRegion(region.ValueOf("<YOUR REGION>")).
                WithCredential(auth).
                Build())
    
        request := &model.UpdateTaskStatusRequest{}
    	request.Body = &model.UpdateTaskStatusReq{
    		Operation: model.GetUpdateTaskStatusReqOperationEnum().SYNC_FAILED_ROLLBACK,
    	}
    	response, err := client.UpdateTaskStatus(request)
    	if err == nil {
            fmt.Printf("%+v\n", response)
        } else {
            fmt.Println(err)
        }
    }
    
  • This example pauses the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package main
    
    import (
    	"fmt"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
        sms "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3/model"
        region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/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")
    
        auth := global.NewCredentialsBuilder().
            WithAk(ak).
            WithSk(sk).
            Build()
    
        client := sms.NewSmsClient(
            sms.SmsClientBuilder().
                WithRegion(region.ValueOf("<YOUR REGION>")).
                WithCredential(auth).
                Build())
    
        request := &model.UpdateTaskStatusRequest{}
    	request.Body = &model.UpdateTaskStatusReq{
    		Operation: model.GetUpdateTaskStatusReqOperationEnum().STOP,
    	}
    	response, err := client.UpdateTaskStatus(request)
    	if err == nil {
            fmt.Printf("%+v\n", response)
        } else {
            fmt.Println(err)
        }
    }
    
  • This example restarts the task with ID 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package main
    
    import (
    	"fmt"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
        sms "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3/model"
        region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/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")
    
        auth := global.NewCredentialsBuilder().
            WithAk(ak).
            WithSk(sk).
            Build()
    
        client := sms.NewSmsClient(
            sms.SmsClientBuilder().
                WithRegion(region.ValueOf("<YOUR REGION>")).
                WithCredential(auth).
                Build())
    
        request := &model.UpdateTaskStatusRequest{}
    	request.Body = &model.UpdateTaskStatusReq{
    		Operation: model.GetUpdateTaskStatusReqOperationEnum().RESTART,
    	}
    	response, err := client.UpdateTaskStatus(request)
    	if err == nil {
            fmt.Printf("%+v\n", response)
        } else {
            fmt.Println(err)
        }
    }
    
  • This example uploads the logs of the task whose ID is 7a9a9540-ff28-4869-b9e4-855fbe12xxxx.

     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
    package main
    
    import (
    	"fmt"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
        sms "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3"
    	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/v3/model"
        region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/sms/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")
    
        auth := global.NewCredentialsBuilder().
            WithAk(ak).
            WithSk(sk).
            Build()
    
        client := sms.NewSmsClient(
            sms.SmsClientBuilder().
                WithRegion(region.ValueOf("<YOUR REGION>")).
                WithCredential(auth).
                Build())
    
        request := &model.UpdateTaskStatusRequest{}
    	request.Body = &model.UpdateTaskStatusReq{
    		Operation: model.GetUpdateTaskStatusReqOperationEnum().COLLECT_LOG,
    	}
    	response, err := client.UpdateTaskStatus(request)
    	if err == nil {
            fmt.Printf("%+v\n", response)
        } else {
            fmt.Println(err)
        }
    }
    

For more SDK sample code of programming languages, visit API Explorer and click the Sample Code tab. Example code can be automatically generated.

Status Codes

Status Code

Description

200

Response returned.

Error Codes

For details, see Error Codes.