Listing All Nodes in a Cluster
Function
This API is used to obtain details about all nodes in a specified cluster with the cluster ID.
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
GET /api/v3/projects/{project_id}/clusters/{cluster_id}/nodes
|
Parameter |
Mandatory |
Type |
Description |
|---|---|---|---|
|
project_id |
Yes |
String |
Project ID. For details about how to obtain the project ID, see How to Obtain Parameters in the API URI. |
|
cluster_id |
Yes |
String |
Cluster ID. For details about how to obtain the cluster ID, see How to Obtain Parameters in the API URI. |
|
Parameter |
Mandatory |
Type |
Description |
|---|---|---|---|
|
errorStatus |
No |
String |
This field allows a cluster to be in the Error state if exceptions occur when the cluster is being deleted. If the value of errorStatus is null, the cluster stays in the Deleting state, but not Error. Minimum: 0 Maximum: 10 |
Request Parameters
|
Parameter |
Mandatory |
Type |
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 field is mandatory and must be set to a user token. For details about how to obtain a token, see Authentication. Maximum: 16384 |
Response Parameters
Status code: 200
|
Parameter |
Type |
Description |
|---|---|---|
|
kind |
String |
API type. The value is fixed at List. Default: List |
|
apiVersion |
String |
API version. The value is fixed at v3. Default: v3 |
|
items |
Array of V3Node objects |
List of all nodes in the current cluster. You can filter nodes by items.metadata.name. |
|
Parameter |
Type |
Description |
|---|---|---|
|
kind |
String |
API type. The value is fixed at Node and cannot be changed. Default: Node |
|
apiVersion |
String |
API version. The value is fixed at v3 and cannot be changed. Default: v3 |
|
metadata |
NodeMetadata object |
Node metadata, which is a collection of attributes. |
|
spec |
V3NodeSpec object |
Detailed description of the node object. CCE creates or updates objects by defining or updating spec. |
|
status |
V3NodeStatus object |
Node status, which is dynamically recorded. A user-defined value will not function when a node is being created or modified. |
|
Parameter |
Type |
Description |
|---|---|---|
|
name |
String |
Node name.
NOTE:
Enter 1 to 56 characters, starting with a lowercase letter and not ending with a hyphen (-). Only lowercase letters, digits, and hyphens (-) are allowed. Minimum: 1 Maximum: 56 |
|
uid |
String |
Node ID, which is unique and automatically generated after the resource is created. A user-defined ID will not take effect. |
|
labels |
Map<String,String> |
CCE node label (not the native Kubernetes label). Labels are used to select objects that meet certain criteria. A label is a key-value pair. Example: "labels": {
"key" : "value"
} |
|
annotations |
Map<String,String> |
CCE node annotations in key-value pairs (not the native Kubernetes annotations). Example: "annotations": {
"key1" : "value1",
"key2" : "value2"
}
NOTE:
annotations is not used to identify or select objects. Metadata in annotations can be small or large, structured or unstructured, and can include characters that are not allowed in labels. |
|
creationTimestamp |
String |
Time when the object was created. The value is automatically generated after the object is created. A user-defined value will not take effect. |
|
updateTimestamp |
String |
Time when the object was updated. The value is automatically generated after the object is created. A user-defined value will not take effect. |
|
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.
NOTE:
The system automatically selects the supported OS based on the cluster version. If the current cluster version does not support the OS, an error will be reported.
|
|
login |
Login object |
Node login mode. |
|
rootVolume |
V3RootVolume object |
System disk information of the node. |
|
dataVolumes |
Array of V3DataVolume objects |
Data disk parameters of the node. Currently, you can add the second data disk for your node on the CCE console. For DeC nodes, the parameter description is the same as that for rootVolume. |
|
publicIP |
V3NodePublicIP object |
EIP of the node. |
|
nodeNicSpec |
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. The value can be 0 (pay-per-use) or 2 (yearly/monthly). Tokens of common users can be used to create yearly/monthly-billed nodes with auto payment enabled.
NOTE:
Creating pay-per-use nodes does not affect the cluster status. When you create a yearly/monthly-billed node, the cluster status changes to Scaling out. |
|
taints |
Array of Taint objects |
You can add taints to created nodes to set affinity. Each taint contains the following three parameters: \n\n- Key: The value must start with a letter or digit and can contain letters, digits, hyphens (-), underscores (), and periods (.). The maximum length is 63 characters. In addition, the DNS subdomain can be used as the prefix. \n- Value: The value must start with a letter or digit and can contain a maximum of 63 characters, including letters, digits, hyphens (-), underscores (), and periods (.). \n- Effect: Available options are NoSchedule, PreferNoSchedule, and NoExecute. \n\nExample: \n\n\n"taints": [{\n\t"key": "status",\n\t"value": "unavailable",\n\t"effect": "NoSchedule"\n}, {\n\t"key": "looks",\n\t"value": "bad",\n\t"effect": "NoSchedule"\n}]\n |
|
k8sTags |
Map<String,String> |
The format is a key-value pair. The number of key-value pairs cannot exceed 20. \n\n- Key: Enter 1 to 63 characters, starting with a letter or digit. Only letters, digits, hyphens (-), underscores (), and periods (.) are allowed. A DNS subdomain can be prefixed to a key and contain a maximum of 253 characters. Example DNS subdomain: example.com/my-key \n- Value: The value can be left blank or contain 1 to 63 characters that start with a letter or digit. Only letters, digits, hyphens (-), underscores (), and periods (.) are allowed in the character string. \n\nExample: \n\n\n"k8sTags": {\n\t"key": "value"\n}\n |
|
ecsGroupId |
String |
Cloud server group ID. If this field is specified, the node is created in the specified cloud server group. |
|
dedicatedHostId |
String |
ID of the DeH to which the node is scheduled. \n>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 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:
This field is valid and mandatory when billingMode is set to 2 (yearly/monthly-billed with auto payment enabled).
NOTE:
This field is valid and mandatory when billingMode is set to 2.
NOTE:
This field is valid and mandatory when billingMode is set to 2.
NOTE:
This field is valid when billingMode is set to 2. If this field is not specified, fees are automatically deducted by default.
"DockerLVMConfigOverride":"dockerThinpool=vgpaas/90%VG;kubernetesLV=vgpaas/10%VG;diskType=evs;lvType=linear" The configuration contains the following fields:
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. |
|
userPassword |
UserPassword object |
Password used for node login. Either the key pair or password must be used for login. |
|
Parameter |
Type |
Description |
|---|---|---|
|
username |
String |
Login account. The default value is root. Default: root |
|
password |
String |
Login password. For details, see the description of the adminPass parameter in Creating an ECS. If a username and password are used to create a node, this field is shielded in the response body. Add a salt to the password field when creating a node. For details, see Adding a Salt in the password Field When Creating a Node. |
|
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. |
|
cluster_id |
String |
ID of the storage pool used by the ECS system disk. This field is used only for DeC clusters, which functions as dssPoolID, that is, ID of the DSS storage pool. To obtain the value, see the ID field in "Table 3 Response parameters" in Obtaining Details of a DSS Storage Pool. |
|
cluster_type |
String |
Storage class of the ECS system disk. The value is always dss. This field is used only for DeC clusters. |
|
hw:passthrough |
Boolean |
|
|
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. |
|
cluster_id |
String |
ID of the storage pool used by the ECS system disk. This field is used only for DeC clusters, which functions as dssPoolID, that is, ID of the DSS storage pool. To obtain the value, see the ID field in "Table 3 Response parameters" in Obtaining Details of a DSS Storage Pool. |
|
cluster_type |
String |
Storage class of the ECS system disk. The value is always dss. This field is used only for DeC clusters. |
|
hw:passthrough |
Boolean |
|
|
metadata |
DataVolumeMetadata object |
Data disk encryption information. This field is mandatory only when the data disk of the node to be created needs to be encrypted. |
|
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 object |
EIP configuration. |
|
Parameter |
Type |
Description |
|---|---|---|
|
iptype |
String |
EIP type. For details, see the description of the iptype field in the eip parameter description in Data Structure for Creating ECSs. |
|
bandwidth |
V3NodeBandwidth object |
Bandwidth parameters of the EIP. |
|
Parameter |
Type |
Description |
|---|---|---|
|
chargemode |
String |
2- Bandwidth billing modes:
NOTE:
NOTE:
|
|
size |
String |
Bandwidth size. For details, see the description of the size field in the bandwidth parameter description in Data Structure for Creating ECSs. |
|
sharetype |
String |
Bandwidth sharing type. For details, see the description of the sharetype field in the bandwidth parameter description in Data Structure for Creating ECSs. |
|
Parameter |
Type |
Description |
|---|---|---|
|
primaryNic |
NicSpec object |
Description of the primary NIC. |
|
extNics |
Array of NicSpec objects |
Extension NIC. |
|
Parameter |
Type |
Description |
|---|---|---|
|
subnetId |
String |
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 |
|---|---|---|
|
phase |
String |
Node status. Enumeration values:
|
|
jobID |
String |
ID of a creation or deletion job. |
|
serverId |
String |
ID of the underlying ECS or BMS node. |
|
privateIP |
String |
IP address in the private network segment of the primary NIC on the node. |
|
publicIP |
String |
Node EIP. If the ECS data is not synchronized in real time, you can click Sync Node Data on the console to manually update the data. |
|
deleteStatus |
DeleteStatus object |
Resource status during resource deletion. |
|
Parameter |
Type |
Description |
|---|---|---|
|
previous_total |
Integer |
Total number of existing cluster resource records when the cluster is deleted. |
|
current_total |
Integer |
Latest number of resource records, which is generated based on the current cluster resource records. |
|
updated |
Integer |
Total number of resource records updated when the cluster is deleted. |
|
added |
Integer |
Total number of resource records updated when the cluster is deleted. |
|
deleted |
Integer |
Total number of resource records deleted when the cluster is deleted. |
Example Requests
None
Example Responses
Status code: 200
Information about all the nodes in the specified cluster is successfully obtained.
{
"kind" : "List",
"apiVersion" : "v3",
"items" : [ {
"kind" : "Node",
"apiversion" : "v3",
"metadata" : {
"name" : "myhost",
"uid" : "4d1ecb2c-229a-11e8-9c75-0255ac100ceb",
"creationTimestamp" : "2018-08-02 07:37:24.005071325 +0000 UTC",
"updateTimestamp" : "2018-08-02 07:44:04.965500815 +0000 UTC",
"annotations" : {
"kubernetes.io/node-pool.id" : "az1.dc1#s1.medium#EulerOS 2.2"
}
},
"spec" : {
"flavor" : "s1.medium",
"az" : "az1.dc1",
"os" : "EulerOS 2.2",
"login" : {
"sshKey" : "KeyPair-0405",
"userPassword" : { }
},
"rootVolume" : {
"volumetype" : "SATA",
"size" : 40
},
"dataVolumes" : [ {
"volumetype" : "SATA",
"size" : 100
} ],
"publicIP" : {
"eip" : {
"bandwidth" : { }
}
},
"billingMode" : 0
},
"status" : {
"phase" : "Active",
"serverId" : "456789abc-9368-46f3-8f29-d1a95622a568",
"publicIP" : "10.34.56.78",
"privateIP" : "192.168.1.23"
}
} ]
}
Status Codes
|
Status Code |
Description |
|---|---|
|
200 |
Information about all the nodes in the specified cluster is successfully obtained. |
Error Codes
See Error Codes.
Last Article: Reading a Specified Node
Next Article: Updating a Specified Node
Did this article solve your problem?
Thank you for your score!Your feedback would help us improve the website.