Creating a Node¶
Function¶
This API is used to create a node in a specified cluster.
URI¶
POST /api/v3/projects/{project_id}/clusters/{cluster_id}/nodes
Table 1 describes the parameters of the 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. |
cluster_id | Yes | Cluster ID. For details about how to obtain the cluster ID, see How to Obtain Parameters in the API URI. |
Request¶
Request parameters:
Table 2 and Table 3 describe the request parameters.
Parameter | Mandatory | Description |
---|---|---|
Content-Type | Yes | Message body type (format). Possible values:
|
X-Auth-Token | Yes | 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. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
kind | Yes | String | API type. The value is fixed at Node and cannot be changed. |
apiVersion | Yes | String | API version. The value is fixed at v3 and cannot be changed. |
metadata | Yes | metadata object | Node's metadata, which is a collection of attributes. |
spec | Yes | spec object | Detailed description of the node targeted by this API. CCE creates or updates objects by defining or updating its spec. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
name | No | String | Node name. Enter 0 to 56 characters starting with a letter and not ending with a hyphen (-). Only lowercase letters, digits, and hyphens (-) are allowed. If no node name is specified, the system automatically generates a node name in the format of Cluster Name-*****. |
labels | No | Object | 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"
}
Users can not use this field to define the native Kubernetes labels. |
annotations | No | Object | CCE node annotation in key-value pair format (not the native Kubernetes annotations). Example: "annotations": {
"key1" : "value1",
"key2" : "value2"
}
|
Parameter | Mandatory | Type | Description |
---|---|---|---|
flavor | Yes | String | Node specifications.
|
az | Yes | String | AZ of the node. |
os | No | String | Node OS.
If the alpha.cce/NodeImageID parameter in extendParam is specified during node creation, you do not need to set this field. |
dedicatedHostId | No | String | ID of the dedicated host to which nodes will be scheduled. |
login | Yes | login object | Node login mode, which can be key pair or password. |
rootVolume | Yes | Volume object | System disk parameters of the node. |
dataVolumes | Yes | Array of Volume object | Data disk parameters of the node. Currently, you can add the second data disk for your node on the CCE console. |
storage | No | Storage object | Disk initialization management parameter. This parameter is complex to configure. For details, see Attaching Disks to a Node. If this parameter retains its default, disks are managed based on the DockerLVMConfigOverride (discarded) parameter in extendParam. This parameter is supported by clusters of version 1.15.11 and later. If a node specification involves local disks and EVS disks at the same time, do not retain the default value of this parameter to prevent unexpected disk partitions. |
publicIP | No | publicIP object | EIP used by the node to access public networks. |
billingMode | No | Integer | Billing mode of a node. This field is not supported for the current version. |
count | Yes | 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 fielder can be set to 0 for a node pool. |
nodeNicSpec | No | nodeNicSpec object | Description about the node NIC. |
extendParam | No | extendParam object | Extended parameter. Format: Key-value pair. |
userTags | No | Object | Tag of a VM. The format is key-value pair. The number of key-value pairs cannot exceed 20.
Example: "userTags": [
{
"key": "tag1",
"value": "aaaa"
},
{
"key": "tag2",
"value": "bbbb"
}
]
|
k8sTags | No | Object | Tag of a Kubernetes node. The format is key-value pair. The number of key-value pairs cannot exceed 20.
Example: "k8sTags": {
"key": "value"
}
|
taints | No | Object | You can add taints to created nodes to configure anti-affinity. Each taint contains the following parameters:
Example: "taints": [{
"key": "status",
"value": "unavailable",
"effect": "NoSchedule"
}, {
"key": "looks",
"value": "bad",
"effect": "NoSchedule"
}]
|
ecsGroupId | No | String | ECS group ID. If this parameter is specified, the node is created in the specified ECS group. |
dedicatedHostId | No | String | ID of the DeH host. If this parameter is specified, the node is scheduled to its own DeH host. This parameter is not supported when you add a node to a node pool. |
offloadNode | No | Boolean | Whether the node belongs to a CCE Turbo cluster. This parameter is not supported when you add a node to a node pool. |
faultDomain | No | String | Cloud server fault domain. The node is created in the fault domain specified by this parameter. You must specify the ECS to which the fault domain policy applies and enable the fault domain feature. |
runtime | No | Runtime object | Container runtime. The default value is docker. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
primaryNic | No | primaryNic object | Description about the primary NIC. |
extNics | No | Array of extNics objects | Extension NIC. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
subnetId | No | String | Network ID of the subnet to which the NIC belongs. |
fixedIps | No | 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 | No | 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 | Mandatory | Type | Description |
---|---|---|---|
maxPods | No | Integer | Maximum number of pods on the node. |
agency_name | No | String | Specifies the IAM agency name. |
dockerBaseSize | No | Integer | Available disk space of a single Docker container on the node using the device mapper. |
alpha.cce/preInstall | No | String | Script required before the installation. The input value must be encoded using Base64. (Command: echo -n "Content to be encoded" | base64) |
alpha.cce/postInstall | No | String | Script required after the installation. The input value must be encoded using Base64. (Command: echo -n "Content to be encoded" | base64) |
alpha.cce/NodeImageID | No | String | Mandatory if a custom image is used in creating a bare metal node. |
DockerLVMConfigOverride | No | String | Docker data disk configuration item. (This parameter has been discarded. Use the storage field instead.)The following is an example configuration: "DockerLVMConfigOverride":"dockerThinpool=vgpaas/90%VG;kubernetesLV=vgpaas/10%VG;diskType=evs;lvType=linear"
In this example:
|
Parameter | Mandatory | Type | Description |
---|---|---|---|
sshKey | No | String | Name of the key pair used for node login. For details on how to create a key pair, see Creating a Key Pair. |
userPassword | No | String | Password used for node login. This field is not supported for the current version. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
volumetype | No | String | Disk type.
|
size | No | Integer | Disk size, in GB. Value range for system disks: 40 to 1024. Value range for data disks: 100 to 32768. |
extendParam | No | Map<String,Object> | Disk extension parameter. For details, see the description of the extendparam parameter in Creating an ECS. |
hw:passthrough | No | Boolean |
|
metadata | No | 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 | Mandatory | Type | Description |
---|---|---|---|
__system__encrypted | No | String | Whether an EVS disk is encrypted.
If this parameter is not specified, EVS disks will not be encrypted by default. |
__system__cmkid | Yes | String | CMK ID used for encryption. This parameter is used with __system__encrypted. You can obtain the ID through HTTPS requests. For details, see Querying the List of CMKs. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
ids | No | Array of strings | List of IDs of the existing EIPs. NOTICE: If ids is set, you do not need to set count and eip. |
count | No | Integer | Number of EIPs to be dynamically created. NOTICE: The count and eip parameters must be set simultaneously. |
eip | No | eip object | EIP. NOTICE: The count and eip parameters must be set simultaneously. |
If no EIP has been created, configure count and eip. The system will automatically create EIPs based on count and eip.
Parameter | Mandatory | Type | Description |
---|---|---|---|
iptype | Yes | String | EIP type. |
bandwidth | Yes | bandwidth object | Bandwidth parameters of the EIP. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
chargemode | No | String | The value is traffic, indicating that the billing is based on traffic. |
size | Yes | Integer | Bandwidth size. |
sharetype | Yes | String | Shared bandwidth type. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
name | No | String | Container runtime. The default value is docker. Enumeration values:
|
Parameter | Mandatory | Type | Description |
---|---|---|---|
storageSelectors | Yes | Array of StorageSelectors objects | Disk selection. Matched disks are managed according to matchLabels and storageType. |
storageGroups | Yes | Array of StorageGroups objects | A storage group consists of multiple storage devices. It is used to divide storage space. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
name | Yes | String | Selector name, used as the index of selectorNames in storageGroup. Therefore, the name of each selector must be unique. |
storageType | Yes | String | Specifies the storage type. Currently, only evs (EVS volumes) and local (local volumes) are supported. The local storage does not support disk selection. All local disks will form a VG. Therefore, only one storageSelector of the local type is allowed. |
matchLabels | No | matchLabels object | Matching field of an EVS volume. The size, volumeType, metadataEncrypted, metadataCmkid and count fields are supported. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
size | No | String | Matched disk size. If this parameter is left unspecified, the disk size is not limited. Example: 100 |
volumeType | No | String | EVS disk type. |
metadataEncrypted | No | String | Disk encryption identifier. 0 indicates that the disk is not encrypted, and 1 indicates that the disk is encrypted. |
metadataCmkid | No | String | Customer master key ID of an encrypted disk. The value is a 36-byte string. |
count | No | String | Number of disks to be selected. If this parameter is left blank, all disks of this type are selected. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
name | Yes | String | Name of a virtual storage group, which must be unique. |
cceManaged | No | Boolean | Storage space for Kubernetes and runtime components. Only one group can be set to true. If this parameter is left blank, the default value false is used. |
selectorNames | Yes | Array of strings | This parameter corresponds to name in storageSelectors. A group can match multiple selectors, but a selector can match only one group. |
virtualSpaces | Yes | Array of VirtualSpace objects | Detailed management of space configuration in a group. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
name | Yes | String | Name of a virtualSpace.
|
size | Yes | String | Size of a virtualSpace. The value must be an integer in percentage. Example: 90%. The sum of the percentages of all virtualSpaces in a group cannot exceed 100%. |
lvmConfig | No | LVMConfig object | LVM configurations, applicable to kubernetes and user spaces. Note that one virtual space supports only one config. |
runtimeConfig | No | RuntimeConfig object | runtime configurations, applicable to the runtime space. Note that one virtual space supports only one config. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
lvType | Yes | String | LVM write mode. linear indicates the linear mode. striped indicates the striped mode, in which multiple disks are used to form a strip to improve disk performance. |
path | No | String | Path to which the disk is attached. This parameter takes effect only in user configuration. The value is an absolute path. Digits, letters, periods (.), hyphens (-), and underscores (_) are allowed. |
Parameter | Mandatory | Type | Description |
---|---|---|---|
lvType | Yes | String | LVM write mode. linear indicates the linear mode. striped indicates the striped mode, in which multiple disks are used to form a strip to improve disk performance. |
Example request:
CCE cluster:
{
"kind": "Node",
"apiVersion": "v3",
"metadata": {
"name": "myhost",
"labels": {
"foo": "bar"
},
"annotations": {
"annotation1": "abc"
}
},
"spec": {
"flavor": "c4.large.2",
"az": "",
"login": {
"sshKey": "Keypair-demo"
},
"rootVolume": {
"size": 40,
"volumetype": "SAS"
},
"dataVolumes" : [ {
"size" : 100,
"volumetype" : "SAS"
} ],
"storage": {
"storageSelectors": [
{
"name": "cceUse",
"storageType": "evs",
"matchLabels": {
"size": "100",
"volumeType": "SAS",
"count": "1"
}
}
],
"storageGroups": [
{
"name": "vgpaas",
"selectorNames": [
"cceUse"
],
"cceManaged": true,
"virtualSpaces": [
{
"name": "runtime",
"size": "90%"
},
{
"name": "kubernetes",
"size": "10%"
}
]
}
]
},
"userTags": [
{
"key": "tag1",
"value": "aaaa"
},
{
"key": "tag2",
"value": "bbbb"
}
],
"k8sTags": {
"label-test": "test"
},
"publicIP": {
"count": 2,
"eip": {
"iptype": "5_bgp",
"bandwidth": {
"chargemode": "traffic",
"size": 10,
"sharetype": "PER"
}
}
},
"count": 2,
"nodeNicSpec": {
"primaryNic": {
"subnetId": "bbfc0a20-d66c-4f36-b4c1-265d669b8c62"
}
},
"extendParam": {
"alpha.cce/postInstall": "IyEvYml******C50eHQ="
}
}
}
Response¶
Response parameters:
Table 23 describes the response parameters.
Parameter | Type | Description |
---|---|---|
kind | String | API type. The value is fixed at Node and cannot be changed. |
apiVersion | String | API version. The value is fixed at v3 and cannot be changed. |
metadata | metadata object | Node's metadata, which is a collection of attributes. |
spec | spec object | Detailed description of the node targeted by this API. CCE creates or updates objects by defining or updating its spec. |
status | status object | Node status and jobID of the node creation job. |
Parameter | Type | Description |
---|---|---|
name | String | Node name. |
uid | String | Node ID. |
labels | Object | 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"
}
Users can not use this field to define the native Kubernetes labels. |
annotations | Object | CCE node annotation in key-value pair format (not the native Kubernetes annotations). Example: "annotations": {
"key1" : "value1",
"key2" : "value2"
}
|
Parameter | Type | Description |
---|---|---|
flavor | String | Node specifications. |
az | String | AZ of the node. |
os | String | Node OS.
|
login | login object | Node login mode, which can only be key pair. |
rootVolume | Volume object | System disk parameters of the node. |
dataVolumes | Array of Volume object | Data disk parameters of the node. |
storage | Storage object | Disk initialization management parameter. This parameter is complex to configure. For details, see Attaching Disks to a Node. If this parameter retains its default, disks are managed based on the DockerLVMConfigOverride (discarded) parameter in extendParam. This parameter is supported by clusters of version 1.15.11 and later. If a node specification involves local disks and EVS disks at the same time, do not retain the default value of this parameter to prevent unexpected disk partitions. |
publicIP | publicIP object | EIP parameters of a node. |
nodeNicSpec | nodeNicSpec object | Description about the node NIC. |
count | Integer | Number of nodes to be created in a batch. The value must be a positive integer greater than or equal to 1. This parameter can be set to 0 for a node pool. |
billingMode | Integer | Billing mode of a node. This field is not supported for the current version. |
userTags | Object | The format is key-value pair. It is recommended that you use TMS's predefined tag function to add the same tag to different cloud resources.
Example: "userTags": [
{
"key": "tag1",
"value": "aaaa"
}, {
"key": "tag2",
"value": "bbbb"
}]
|
k8sTags | Object | The format is key-value pair. The number of key-value pairs cannot exceed 20.
If a node is created using a node pool, a label whose key is cce.cloud.com/cce-nodepool is automatically added to the node, and the label value is the node name. Example: "k8sTags": {
"key": "value"
}
|
taints | Object | You can add taints to created nodes to configure anti-affinity. Each taint contains the following parameters:
Example: "taints": [{
"key": "status",
"value": "unavailable",
"effect": "NoSchedule"
}, {
"key": "looks",
"value": "bad",
"effect": "NoSchedule"
}]
|
ecsGroupId | String | ECS group ID. If this parameter is specified, the node is created in the specified ECS group. |
dedicatedHostId | String | ID of the DeH host. If this parameter is specified, the node is scheduled to its own DeH host. This parameter is not supported when you add a node to a node pool. |
offloadNode | Boolean | Whether the node belongs to a CCE Turbo cluster. This parameter is not supported when you add a node to a node pool. |
faultDomain | String | Cloud server fault domain. The node is created in the fault domain specified by this parameter. You must specify the ECS to which the fault domain policy applies and enable the fault domain feature. |
extendParam | extendParam object | Extended parameter. Format: Key-value pair. |
runtime | Runtime object | Container runtime. The default value is docker. |
Parameter | Type | Description |
---|---|---|
primaryNic | primaryNic object | Description about the primary NIC. |
extNics | Array of extNics 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 |
---|---|---|
chargingMode | Integer | Billing mode of a node. This field is not supported for the current version. |
ecs:performancetype | String | Type of the ECS specifications. |
orderID | String | Order ID. This field is not supported for the current version. |
productID | String | Product ID. This field is not supported for the current version. |
publicKey | String | Key pair used to log in to the node. Used when creating a key pair. |
maxPods | Integer | Maximum number of pods on the node. |
dockerBaseSize | Integer | Available disk space of a single Docker container on the node using the device mapper. |
agency_name | String | Specifies the IAM agency name. |
DockerLVMConfigOverride | String | Docker data disk configuration item. (This parameter has been discarded. Use the storage field instead.) The following is the default configuration: "DockerLVMConfigOverride":"dockerThinpool=vgpaas/90%VG;kubernetesLV=vgpaas/10%VG;diskType=evs;lvType=linear"
The configuration contains the following fields:
|
Parameter | Type | Description |
---|---|---|
jobID | String | ID of the node creation job. You can query job progress by job ID to keep updated on node creation progress. |
phase | String | Node status.
|
serverId | String | ID of the underlying ECS 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. |
privateIP | String | IP address in the private network segment of the primary NIC on the node. |
Parameter | Type | Description |
---|---|---|
name | String | Container runtime. The default value is docker. Enumeration values:
|
Parameter | Type | Description |
---|---|---|
storageSelectors | Array of StorageSelectors objects | Disk selection. Matched disks are managed according to matchLabels and storageType. |
storageGroups | Array of StorageGroups objects | A storage group consists of multiple storage devices. It is used to divide storage space. |
Parameter | Type | Description |
---|---|---|
name | String | Selector name, used as the index of selectorNames in storageGroup. Therefore, the name of each selector must be unique. |
storageType | String | Specifies the storage type. Currently, only evs (EVS volumes) and local (local volumes) are supported. The local storage does not support disk selection. All local disks will form a VG. Therefore, only one storageSelector of the local type is allowed. |
matchLabels | matchLabels object | Matching field of an EVS volume. The size, volumeType, metadataEncrypted, metadataCmkid and count fields are supported. |
Parameter | Type | Description |
---|---|---|
size | String | Matched disk size. If this parameter is left unspecified, the disk size is not limited. Example: 100 |
volumeType | String | EVS disk type. Currently, SSD, GPSSD and SAS are supported. |
metadataEncrypted | String | Disk encryption identifier. 0 indicates that the disk is not encrypted, and 1 indicates that the disk is encrypted. |
metadataCmkid | String | Customer master key ID of an encrypted disk. The value is a 36-byte string. |
count | String | Number of disks to be selected. If this parameter is left blank, all disks of this type are selected. |
Parameter | Type | Description |
---|---|---|
name | String | Name of a virtual storage group, which must be unique. |
cceManaged | Boolean | Storage space for Kubernetes and runtime components. Only one group can be set to true. If this parameter is left blank, the default value false is used. |
selectorNames | Array of strings | This parameter corresponds to name in storageSelectors. A group can match multiple selectors, but a selector can match only one group. |
virtualSpaces | Array of VirtualSpace objects | Detailed management of space configuration in a group. |
Parameter | Type | Description |
---|---|---|
name | String | Name of a virtualSpace.
|
size | String | Size of a virtualSpace. The value must be an integer in percentage. Example: 90%. The sum of the percentages of all virtualSpaces in a group cannot exceed 100%. |
lvmConfig | LVMConfig object | LVM configurations, applicable to kubernetes and user spaces. Note that one virtual space supports only one config. |
runtimeConfig | RuntimeConfig object | runtime configurations, applicable to the runtime space. Note that one virtual space supports only one config. |
Parameter | Type | Description |
---|---|---|
lvType | String | LVM write mode. linear indicates the linear mode. striped indicates the striped mode, in which multiple disks are used to form a strip to improve disk performance. |
path | String | Path to which the disk is attached. This parameter takes effect only in user configuration. The value is an absolute path. Digits, letters, periods (.), hyphens (-), and underscores (_) are allowed. |
Parameter | Type | Description |
---|---|---|
lvType | String | LVM write mode. linear indicates the linear mode. striped indicates the striped mode, in which multiple disks are used to form a strip to improve disk performance. |
Example response:
{
"kind": "Node",
"apiVersion": "v3",
"metadata": {
"name": "myhost",
"uid": "4d1ecb2c-229a-11e8-9c75-0255ac100ceb",
"labels": {
"foo": "bar"
},
"annotations": {
"annotation1": "abc"
}
},
"spec": {
"flavor": "s1.medium",
"az": "",
"os": "EulerOS 2.5",
"login": {
"sshKey": "Keypai-demo"
},
"rootVolume": {
"volumetype": "SAS",
"size": 40
},
"dataVolumes": [
{
"volumetype": "SAS",
"size": 100
}
],
"storage": {
"storageSelectors": [
{
"name": "cceUse",
"storageType": "evs",
"matchLabels": {
"size": "100",
"volumeType": "SAS",
"count": "1"
}
}
],
"storageGroups": [
{
"name": "vgpaas",
"selectorNames": [
"cceUse"
],
"cceManaged": true,
"virtualSpaces": [
{
"name": "runtime",
"size": "90%"
},
{
"name": "kubernetes",
"size": "10%"
}
]
}
]
},
"publicIP": {
"count": 2,
"eip": {
"iptype": "5_bgp",
"bandwidth": {
"size": 10,
"sharetype": "PER",
"chargemode": "traffic"
}
}
},
"nodeNicSpec": {
"primaryNic": {
"subnetId": "2afc3d7f-07d1-4c25-ba2e-8ee48d253d9f"
}
},
"count": 2,
"extendParam": {
"chargingMode": 0,
"ecs:performancetype": "normal",
"init-node-password": "",
"orderID": "",
"productID": ""
}
},
"status": {
"jobID": "2ec9b78d-9368-46f3-8f29-d1a95622a568"
}
}
Status Code¶
Table 38 describes the status codes of this API.
Status Code | Description |
---|---|
201 | The job for creating a node in a specified cluster is successfully issued. |
For the description about error status codes, see Status Code.