CCE API for Reviewed-by: gtema <artem.goncharov@gmail.com> Co-authored-by: proposalbot <proposalbot@otc-service.com> Co-committed-by: proposalbot <proposalbot@otc-service.com>
107 KiB
- original_name
cce_02_0357.html
Deleting a Node Pool
Function
This API is used to delete a specified node pool.
Note
The URL for cluster management is in the format of https://Endpoint/uri. In the URL, uri indicates the resource path, that is, the path for API access.
URI
DELETE /api/v3/projects/{project_id}/clusters/{cluster_id}/nodepools/{nodepool_id}
Table 1 <cce_02_0357__table127923532918>
describes the parameters of this API.
Parameter | Mandatory | Description |
---|---|---|
project_id | Yes | Project ID. For details about how to obtain the project ID, see How to Obtain Parameters in the API URI <cce_02_0271> . |
cluster_id | Yes | Cluster ID. For details about how to obtain the cluster ID, see How to Obtain Parameters in the API URI <cce_02_0271> . |
nodepool_id | Yes | Node pool ID. For details about how to obtain the node pool ID, see Listing All Node Pools in a Specified Cluster <cce_02_0269> . |
Request
Request parameters:
Table 1 <cce_02_0357__table127923532918>
describe the request parameters.
Parameter | Mandatory | String | Description |
---|---|---|---|
Content-Type | Yes | String | Message body type (format). Default: application/json |
X-Auth-Token | Yes | String | Requests for calling an API can be authenticated using either a token or AK/SK. If token-based authentication is used, this parameter is mandatory and must be set to a user token. For details on how to obtain a user token, see API Usage Guidelines <cce_02_0344> . |
Example request:
NA
Response
Response parameters:
Parameter | Type | Description |
---|---|---|
kind | String | API type. The value is fixed at NodePool. Default: NodePool |
apiVersion | String | API version. The value is fixed at v3. Default: v3 |
metadata | NodePoolMetadata <cce_02_0357__response_nodepoolmetadata> object |
Metadata information of the node pool. |
spec | NodePoolSpec <cce_02_0357__response_nodepoolspec> object |
Node pool specifications. |
status | NodePoolStatus <cce_02_0357__response_nodepoolstatus> object |
Node pool status. |
Parameter | Type | Description |
---|---|---|
name | String | Node pool name. Note Naming rules:
Minimum: 1 Maximum: 50 |
uid | String | UID of the node pool. The value is automatically generated after the object is updated. A user-defined value will not take effect. |
Parameter | Type | Description |
---|---|---|
type | String | Node pool type. If this parameter is left blank, the value vm is used by default.
|
nodeTemplate | V3NodeSpec <cce_02_0357__response_v3nodespec> object |
Detailed parameters of the node pool template. |
initialNodeCount | Integer | Initial number of nodes for the node pool. |
autoscaling | NodePoolNodeAutoscaling <cce_02_0357__response_nodepoolnodeautoscaling> object |
Auto scaling parameters. |
nodeManagement | NodeManagement <cce_02_0357__response_nodemanagement> object |
Node management configuration. |
Parameter | Type | Description |
---|---|---|
flavor | String | Node specifications. Minimum: 1 Maximum: 50 |
az | String | \t\nName of the AZ where the node is located. This AZ exists at the underlying layer and is in the physical AZ group of the user. Maximum: 200 |
os | String | Node OS. |
login | Login <cce_02_0357__response_login> object |
Node login mode. |
rootVolume | Volume <cce_02_0357__response_v3rootvolume> object |
System disk information of the node. |
dataVolumes | Array of Volume <cce_02_0357__response_v3rootvolume> objects |
Data disk parameters of the node. Currently, you can add the second data disk for your node on the CCE console. |
publicIP | V3NodePublicIP <cce_02_0357__response_v3nodepublicip> object |
EIP of the node. |
nodeNicSpec | NodeNicSpec <cce_02_0357__response_nodenicspec> object |
NIC information of the node. |
count | Integer | Number of nodes to be created in a batch. The value must be a positive integer greater than or equal to 1 and less than or equal to the defined limit. This field can be set to 0 for a node pool. |
billingMode | Integer | Billing mode of a node. Note This field is not supported for the current version. |
taints | Array of Taint <cce_02_0357__response_taint> objects |
You can add taints to created nodes to set affinity. Each taint contains the following three parameters:
Example:
|
k8sTags | Map<String,String> | The format is a key-value pair. The number of key-value pairs cannot exceed 20.
Example:
|
ecsGroupId | String | Cloud server group ID. If this field is specified, the node is created in the specified cloud server group. Note This field is not supported when you use CCE Turbo cluster. |
dedicatedHostId | String | ID of the DeH to which the node is scheduled. This field is not supported when you add a node during node pool creation. |
offloadNode | Boolean | Whether the node belongs to a CCE Turbo cluster. Note This field is not supported when you add a node during node pool creation. |
userTags | Array of UserTag <cce_02_0357__response_usertag> objects |
Cloud server labels. The key of a label must be unique. The maximum number of user-defined labels supported by CCE depends on the region. In the region that supports the least number of labels, you can still create up to 5 labels for a cloud server. |
extendParam | Map<String,Object> | Extended parameter for creating a node. The options are as follows:
Note The input value must be Base64-encoded. (Command: echo -n Content to be encoded | base64)
Note The input value must be Base64-encoded. (Command: echo -n Content to be encoded | base64)
|
Parameter | Type | Description |
---|---|---|
sshKey | String | Name of the key pair used for login. Either the key pair or password must be used for login. For details on how to create a key pair, see |
userPassword | String | Password used for node login. Note This field is not supported for the current version. |
Parameter | Type | Description |
---|---|---|
size | Integer | Disk size in the unit of GB.
|
volumetype | String | Disk type. For details about possible values, see the description of the root_volume parameter in the API used to create an ECS in the ECS API reference.
|
extendParam | Map<String,Object> | Disk extension parameter. For details, see the description of the extendparam parameter in Creating an ECS. |
hw:passthrough | Boolean |
|
metadata | dataVolumeMetadata <cce_02_0357__response_datavolumemetadata> object |
Data disk encryption information. This parameter is mandatory only when the data disk of the node to be created needs to be encrypted. If data disks are created using a data disk image, this parameter cannot be used. |
Parameter | Type | Description |
---|---|---|
__system__encrypted | String | Whether the EVS disk is encrypted. The value 0 indicates that the EVS disk is not encrypted, and the value 1 indicates that the EVS disk is encrypted. If this field does not exist, the disk will not be encrypted by default. |
__system__cmkid | String | CMK ID, which indicates encryption in metadata. This field is used with __system__encrypted. |
Parameter | Type | Description |
---|---|---|
ids | Array of strings | IDs of existing EIPs. The quantity cannot be greater than the number of nodes to be created. Note If the ids parameter has been set, you do not need to set the count and eip parameters. |
count | Integer | Number of EIPs to be dynamically created. Note The count and eip parameters must be set together. |
eip | V3NodeEIPSpec <cce_02_0357__response_v3nodeeipspec> object |
EIP configuration. |
Parameter | Type | Description |
---|---|---|
iptype | String | EIP type. |
bandwidth | V3NodeBandwidth <cce_02_0357__response_v3nodebandwidth> object |
Bandwidth parameters of the EIP. |
Parameter | Type | Description |
---|---|---|
chargemode | String | Bandwidth billing modes:
Note
|
size | String | Bandwidth size. |
sharetype | String | Bandwidth sharing type. |
Parameter | Type | Description |
---|---|---|
primaryNic | primaryNic <cce_02_0357__response_nicspec> object |
Description of the primary NIC. |
extNics | Array of extNics <cce_02_0357__response_nicspec> objects |
Extension NIC. |
Parameter | Type | Description |
---|---|---|
subnetId | String | Network ID of the subnet to which the NIC belongs. |
fixedIps | Array of strings | The IP address of the primary NIC is specified by fixedIps. The number of IP addresses cannot be greater than the number of created nodes. fixedIps and ipBlock cannot be specified at the same time. |
ipBlock | String | CIDR format of the IP address segment. The IP address of the created node falls in this IP address segment. fixedIps and ipBlock cannot be specified at the same time. |
Parameter | Type | Description |
---|---|---|
key | String | Key. |
value | String | Value. Maximum: 63 |
effect | String | Effect. Enumeration values:
|
Parameter | Type | Description |
---|---|---|
key | String | Key of the cloud server label. The value cannot start with CCE- or __type_baremetal. Minimum: 1 Maximum: 36 |
value | String | Value of the cloud server label. Minimum: 0 Maximum: 43 |
Parameter | Type | Description |
---|---|---|
enable | Boolean | Whether to enable auto scaling. Default: false |
minNodeCount | Integer | Minimum number of nodes allowed if auto scaling is enabled. The value cannot be greater than the maximum number of nodes allowed by the cluster specifications. Minimum: 0 |
maxNodeCount | Integer | Maximum number of nodes allowed if auto scaling is enabled. This value must be greater than or equal to the value of minNodeCount and cannot exceed the maximum number of nodes in the cluster specifications. Minimum: 0 |
scaleDownCooldownTime | Integer | Interval between two scaling operations, in minutes. During this period, nodes added after a scale-up will not be deleted. Minimum: 0 Maximum: 2147483647 |
priority | Integer | Weight of a node pool. A node pool with a higher weight has a higher priority during scaling. |
Parameter | Type | Description |
---|---|---|
serverGroupReference | String | Cloud server group ID. If this field is specified, all nodes in the node pool will be created in this group. The group ID can be specified only when you create the node pool and cannot be modified. When you specify a cloud server group, the number of nodes in the node pool cannot exceed the group quota. |
Parameter | Type | Description |
---|---|---|
currentNode | Integer | Number of nodes in the node pool. |
phase | String | Node pool status. If this field is left blank, the node pool is available.
Enumeration values:
|
jobId | String | ID of the job to delete the node pool. |
Response example:
{
"kind": "List",
"apiVersion": "v3",
"items": [
{
"kind": "NodePool",
"apiVersion": "v3",
"metadata": {
"name": "nodepool-name-change",
"uid": "feec6013-cd7e-11ea-8c7a-0255ac100be7"
},
"spec": {
"initialNodeCount": 0,
"type": "vm",
"nodeTemplate": {
"flavor": "s6.large.2",
"az": "eu-de-02",
"os": "EulerOS 2.5",
"login": {
"sshKey": "KeyPair-nodepool",
"userPassword": {}
},
"rootVolume": {
"volumetype": "SAS",
"size": 40
},
"dataVolumes": [
{
"volumetype": "SAS",
"size": 100,
"extendParam": {
"useType": "docker"
}
}
],
"publicIP": {
"eip": {
"bandwidth": {}
}
},
"nodeNicSpec": {
"primaryNic": {
"subnetId": "31be174a-0c7f-4b71-bb0d-d325fecb90ef"
}
},
"billingMode": 0,
"taints": [
{
"key": "change-taints",
"value": "value1",
"effect": "NoExecute"
}
],
"k8sTags": {
"cce.cloud.com/cce-nodepool": "nodepool-name-change",
"change-tag": "value2"
},
"userTags": [
{
"key": "change-resource-tag",
"value": "value3"
}
],
"extendParam": {
"DockerLVMConfigOverride": "dockerThinpool=vgpaas/90%VG;kubernetesLV=vgpaas/10%VG;diskType=evs;lvType=linear",
"alpha.cce/NodeImageID": "85bd7ec5-bca4-4f5f-947b-6c1bf02599d3",
"alpha.cce/postInstall": "bHMgLWwK",
"alpha.cce/preInstall": "bHMgLWw=",
"maxPods": 110
}
},
"autoscaling": {
"enable": true,
"minNodeCount": 2,
"maxNodeCount": 4,
"scaleDownCooldownTime": 10,
"priority": 2
},
"nodeManagement": {
"serverGroupReference": "2129f95a-f233-4cd8-a1b2-9c0acdf918d3"
}
},
"status": {
"currentNode": 0,
"phase": ""
}
}
]
}
Status Code
Table 20 <cce_02_0357__en-us_topic_0079614900_table46761928>
describes the status code of this API.
Status Code | Description |
---|---|
200 | Information about all node pools in the cluster is successfully obtained. |
For details about error status codes, see Status Code <cce_02_0084>
.
Error Codes
See Error Codes <cce_02_0250>
.
For details about the response parameters, see Table 18 <cce_02_0354__table835415466262>
.
Example response:
{
"kind": "NodePool",
"apiVersion": "v3",
"metadata": {
"name": "test-nodepool",
"uid": "65787e3e-cd82-11ea-8ec6-0255ac1001be"
},
"spec": {
"initialNodeCount": 0,
"type": "vm",
"nodeTemplate": {
"flavor": "s6.large.2",
"az": "eu-de-01",
"os": "EulerOS 2.5",
"login": {
"sshKey": "KeyPair-nodepool",
"userPassword": {}
},
"rootVolume": {
"volumetype": "SATA",
"size": 40
},
"dataVolumes": [
{
"volumetype": "SATA",
"size": 100,
"extendParam": {
"useType": "docker"
},
"metadata": {
"__system__cmkid": "1ed68cb7-b09b-423c-8d66-fdd2e063769d",
"__system__encrypted": "1"
}
}
],
"publicIP": {
"eip": {
"bandwidth": {}
}
},
"nodeNicSpec": {
"primaryNic": {
"subnetId": "3d6f5dc2-caf7-4a06-b4ac-11a3a5a49cdd"
}
},
"billingMode": 0,
"taints": [
{
"key": "test-taints",
"value": "test",
"effect": "NoSchedule"
}
],
"k8sTags": {
"cce.cloud.com/cce-nodepool": "test-nodepool",
"test-k8stag": "test"
},
"userTags": [
{
"key": "test-resourcetag",
"value": "test"
}
],
"extendParam": {
"DockerLVMConfigOverride": "dockerThinpool=vgpaas/90%VG;kubernetesLV=vgpaas/10%VG;diskType=evs;lvType=linear",
"alpha.cce/postInstall": "bHMgLWwK",
"alpha.cce/preInstall": "bHMgLWw=",
"maxPods": 100
}
},
"autoscaling": {
"enable": true,
"minNodeCount": 0,
"maxNodeCount": 4,
"scaleDownCooldownTime": 5,
"priority": 1
},
"nodeManagement": {
"serverGroupReference": "2129f95a-f233-4cd8-a1b2-9c0acdf918d3"
}
},
"status": {
"currentNode": 0,
"phase": "Deleting",
"jobId": "d11c13c4-cd82-11ea-8ec6-0255ac1001be"
}
}
Status Code
Table 21 <cce_02_0357__zh-cn_topic_0079614900_table46761928>
describes the status code of this API.
Status Code | Description |
---|---|
200 | The job for deleting a node pool is successfully delivered. |
For details about error status codes, see Status Code <cce_02_0084>
.