华为云用户手册

  • 响应示例 状态码: 200 表示获取集群访问的地址成功。 { "metadata" : { }, "spec" : { "spec" : { "eip" : { "bandwidth" : { } }, "IsDynamic" : false } }, "status" : { "privateEndpoint" : "https://192.168.3.238:5443", "publicEndpoint" : "" }}
  • 响应参数 状态码: 200 表9 响应Body参数 参数 参数类型 描述 apiVersion String API版本,固定值“v3”。 kind String API类型,固定值“RemoveNodesTask”。 spec RemoveNodesSpec object 配置信息 status TaskStatus object 任务状态 表10 RemoveNodesSpec 参数 参数类型 描述 login Login object 节点的登录方式。密钥对和密码登录方式二者必选其一。 nodes Array of NodeItem objects 待操作节点列表 表11 Login 参数 参数类型 描述 sshKey String 选择密钥对方式登录时的密钥对名称。 userPassword UserPassword object 选择密码方式登录时的帐号密码信息,之后可通过此帐号密码登录节点。 表12 UserPassword 参数 参数类型 描述 username String 登录帐号,默认为“root” password String 登录密码,若创建节点通过用户名密码方式,即使用该字段,则响应体中该字段作屏蔽展示。 密码复杂度要求: 长度为8-26位。 密码至少必须包含大写字母、小写字母、数字和特殊字符(!@$%^-_=+[{}]:,./?~#*)中的三种。 密码不能包含用户名或用户名的逆序。 创建节点时password字段需要加盐加密,具体方法请参见创建节点时password字段加盐加密。 表13 NodeItem 参数 参数类型 描述 uid String 节点ID 表14 TaskStatus 参数 参数类型 描述 jobID String 任务ID,供调用者查询任务进度。
  • 请求示例 移除节点 PUT /api/v3/projects/{project_id}/clusters/{cluster_id}/nodes/operation/remove{ "spec" : { "login" : { "sshKey" : "KeyPair-001" }, "nodes" : [ { "uid" : "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" }, { "uid" : "yyyyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy" } ] }}
  • 响应示例 状态码: 200 表示在指定集群下移除节点的作业下发成功。 { "spec" : { "login" : { "sshKey" : "KeyPair-001" }, "nodes" : [ { "uid" : "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" }, { "uid" : "yyyyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy" } ] }, "status" : { "jobID" : "2ec9b78d-9368-46f3-8f29-d1a95622a568" }}
  • 请求参数 表2 请求Header参数 参数 是否必选 参数类型 描述 Content-Type 是 String 消息体的类型(格式) X-Auth-Token 是 String 调用接口的认证方式分为Token和AK/SK两种,如果您使用的Token方式,此参数为必填,请填写Token的值,获取方式请参见获取token。 表3 请求Body参数 参数 是否必选 参数类型 描述 apiVersion 否 String API版本,固定值“v3”。 kind 否 String API类型,固定值“RemoveNodesTask”。 spec 是 RemoveNodesSpec object 配置信息 status 否 TaskStatus object 任务状态 表4 RemoveNodesSpec 参数 是否必选 参数类型 描述 login 是 Login object 节点的登录方式。密钥对和密码登录方式二者必选其一。 nodes 是 Array of NodeItem objects 待操作节点列表 表5 Login 参数 是否必选 参数类型 描述 sshKey 否 String 选择密钥对方式登录时的密钥对名称。 userPassword 否 UserPassword object 选择密码方式登录时的帐号密码信息,之后可通过此帐号密码登录节点。 表6 UserPassword 参数 是否必选 参数类型 描述 username 否 String 登录帐号,默认为“root” password 是 String 登录密码,若创建节点通过用户名密码方式,即使用该字段,则响应体中该字段作屏蔽展示。 密码复杂度要求: 长度为8-26位。 密码至少必须包含大写字母、小写字母、数字和特殊字符(!@$%^-_=+[{}]:,./?~#*)中的三种。 密码不能包含用户名或用户名的逆序。 创建节点时password字段需要加盐加密,具体方法请参见创建节点时password字段加盐加密。 表7 NodeItem 参数 是否必选 参数类型 描述 uid 是 String 节点ID 表8 TaskStatus 参数 是否必选 参数类型 描述 jobID 否 String 任务ID,供调用者查询任务进度。
  • 响应参数 状态码: 200 表3 响应Body参数 参数 参数类型 描述 quotas Array of QuotaResource objects 资源 表4 QuotaResource 参数 参数类型 描述 quotaKey String 资源类型 quotaLimit Integer 配额值 used Integer 已创建的资源个数 unit String 单位 regionId String 局点ID。若资源不涉及此参数,则不返回该参数。 availabilityZoneId String 可用区ID。若资源不涉及此参数,则不返回该参数。
  • 请求示例 纳管一个节点到集群中,且节点操作系统为EulerOS 2.5。 POST /api/v3/projects/{project_id}/clusters/{cluster_id}/nodes/add{ "kind" : "List", "apiVersion" : "v3", "nodeList" : [ { "serverID" : "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", "spec" : { "name" : "my-ecs-0001", "os" : "EulerOS 2.5", "login" : { "sshKey" : "KeyPair-001" } } } ]}
  • URI POST /api/v3/projects/{project_id}/clusters/{cluster_id}/operation/upgrade/retry 表1 路径参数 参数 是否必选 参数类型 描述 project_id 是 String 项目ID,获取方式请参见如何获取接口URI中参数。 cluster_id 是 String 集群ID,获取方式请参见如何获取接口URI中参数。
  • URI POST /api/v3/projects/{project_id}/clusters/{cluster_id}/operation/upgrade/pause 表1 路径参数 参数 是否必选 参数类型 描述 project_id 是 String 项目ID,获取方式请参见如何获取接口URI中参数。 cluster_id 是 String 集群ID,获取方式请参见如何获取接口URI中参数。
  • 错误码说明 当您调用API时,如果遇到“APIGW”开头的错误码,请参见API网关错误码进行处理。 状态码 错误码 错误信息 描述 处理措施 400 CCE.01400001 Invalid request. 请求体不合法。 请参考返回的message和CCE接口文档修改请求体,或联系技术支持。 400 CCE.01400002 Subnet not found in the VPC. 未在VPC中找到子网。 请确认请求体中的子网是否在对应VPC下。 400 CCE.01400003 IPv6 not supported for the subnet. 子网不支持ipv6。 请使用支持ipv6的子网。 400 CCE.01400004 No available flavors for master nodes. Master节点无可用规格。 请更换其他可用的集群规格,或联系技术支持。 400 CCE.01400005 Container network CIDR blocks conflict. 容器网络网段冲突。 请参考返回的message检查容器网段。 400 CCE.01400006 Content type not supported. Content type不合法。 请参考CCE接口文档使用支持的Content type。 400 CCE.01400007 Insufficient cluster quota. 集群配额不足。 请提交工单增加集群配额。 400 CCE.01400008 Insufficient server quota ECS配额不足。 请提交工单增加ECS配额。 400 CCE.01400009 Insufficient CPU quota. ECS CPU配额不足。 请提交工单增加ECS CPU配额。 400 CCE.01400010 Insufficient memory quota. ECS 内存配额不足。 请提交工单增加ECS内存配额。 400 CCE.01400011 Insufficient security group quota. 安全组配额不足。 请提交工单增加安全组配额。 400 CCE.01400012 Insufficient EIP quota. EIP配额不足。 请提交工单增加EIP配额。 400 CCE.01400013 Insufficient volume quota. 磁盘配额不足。 请参考返回的message,提交工单增加相应的磁盘配额。 400 CCE.01400014 Excessive nodes in the cluster. 节点数超出集群规模限制。 请提交工单申请变更集群规格。 400 CCE.01400015 Version not supported. 不受支持的集群版本。 请参考返回的message,创建支持的集群版本。 400 CCE.01400016 Current cluster type does not support this node flavor. 当前集群类型不支持此节点规格。 请参考返回的message,使用正确的节点规格。 400 CCE.01400017 No available container CIDR block found. 没有找到可用的容器网段。 请参考返回的message,使用正确的容器网段。 400 CCE.01400018 This type of OS cannot be created in this CCE version. 当前CCE版本不支持创建该类型的操作系统。 请参考返回的message,使用支持的操作系统。 400 CCE.01400019 Insufficient resource tenant quota. 资源租户配额不足。 请参考返回的message,或联系技术支持。 400 CCE.01400020 Insufficient VPC quota. VPC配额不足。 请参考返回的message,或联系技术支持。 400 CCE.01400021 No available flavors for nodes. 节点无可用规格。 请更换其他可用的节点规格,或联系技术支持。 400 CCE.01400022 No available node volumes for nodes. 节点无可用EVS卷规格。 请更换其他可用的EVS卷规格,或联系技术支持。 400 CCE.02400001 Invalid request. 请求体不合法。 请参考返回的message和CCE接口文档修改请求体,或联系技术支持。 400 CCE.03400001 Invalid request. 请求体不合法。 请参考返回的message和CCE接口文档修改请求体,或联系技术支持。 400 CCE.03400002 Missing access key. 缺少Access key。 请确认安装或升级的存储插件版本正确,或联系技术支持。 401 CCE.01401001 Authorization failed. 认证失败。 请参考返回的message,或联系技术支持。 401 CCE.02401001 Authorization failed. 认证失败。 请参考返回的message,或联系技术支持。 401 CCE.03401001 Authorization failed. 认证失败。 请参考返回的message,或联系技术支持。 403 CCE.01403001 Forbidden. 禁止访问。 请参考返回的message,或联系技术支持。 403 CCE.02403001 Forbidden. 禁止访问。 请参考返回的message,或联系技术支持。 403 CCE.03403001 Forbidden. 禁止访问。 请参考返回的message,或联系技术支持。 404 CCE.01404001 Resource not found. 未找到资源。 请确认要访问的资源是否已被删除。 404 CCE.02404001 Resource not found. 未找到资源。 请确认要访问的资源是否已被删除。 404 CCE.03404001 Resource not found. 未找到资源。 请确认要访问的资源是否已被删除。 409 CCE.01409001 The resource already exists. 资源已存在。 请先删除资源后,再进行创建。 409 CCE.01409002 Resource updated with out-of-date version. 要更新的资源版本已过期。 请确认要更新的资源为版本为最新,或联系技术支持。 409 CCE.02409001 The resource already exists. 资源已存在。 请先删除资源后,再进行创建。 409 CCE.03409001 Addon instance has installed. 插件实例已安装。 请先删除插件实例,再进行安装。 429 CCE.01429002 Resource locked by other requests. 资源被其他请求锁定。 请参考返回的message,或联系技术支持。 429 CCE.02429001 The throttling threshold has been reached. 已达到最大请求数量限制。 请减少发送请求的频率,或联系技术支持。 500 CCE.01500001 Internal error. 内部错误。 请参考返回的message,或联系技术支持。 500 CCE.02500001 Internal error. 内部错误。 请参考返回的message,或联系技术支持。 500 CCE.03500001 Internal error. 内部错误。 请参考返回的message,或联系技术支持。
  • URI POST /api/v3/projects/{project_id}/clusters/{cluster_id}/operation/upgrade/continue 表1 路径参数 参数 是否必选 参数类型 描述 project_id 是 String 项目ID,获取方式请参见如何获取接口URI中参数。 cluster_id 是 String 集群ID,获取方式请参见如何获取接口URI中参数。
  • 解决方案 本文对节点创建中storage字段进行详细的解释说明,方便用户通过创建节点API实现较为复杂的磁盘选择与功能划分。 storage字段由storageSelectors和storageGroups组成:storageSelectors字段负责选盘逻辑,storageGroups字段负责磁盘处理逻辑。 字段匹配基础逻辑如下: storageSelectors根据storageType字段选择evs云盘或是local本地盘。 local本地盘无精确匹配模式,将全选所有本地盘作为数据盘。 若需保留部分本地盘,请在安装前启动脚本中将磁盘占用。类似如下脚本。 # preparevgName=vg-teststorageDevice=/dev/vdb# vgcreatevgcreate ${vgName} ${storageDevice} evs云盘通过matchLabels字段去模糊匹配dataVolumes字段中创建的云盘。 matchLabels的匹配存在优先级,storageSelectors中靠前的策略优先匹配,dataVolumes中靠前的云盘也优先被选择。由于matchLabels采用宽匹配策略,因此建议将匹配范围小的匹配策略前置。例如: 1中匹配大小为100G,存储类型为SAS的evs盘,匹配到dataVolumes中的第一块盘;2中匹配大小为100G的evs盘,由于第一块盘已被选择,因此匹配到第二块盘; 3中匹配大小为100G的evs盘,由于未填写volumeType或count,因此能匹配到dataVolumes中的两块盘,导致4中无可用磁盘匹配。 storageGroups根据selectorName与storageSelectors做关联。最终选择到两块100G的盘。CCE后端将这两块物理卷(PV)组成一个卷组(VG),并以9:1的比例划分两个逻辑卷(LV)。其中10%的kubernetes逻辑卷以条带(striped)方式进行划分。90%的runtime逻辑卷由于未配置runtimeConfig,采用默认的线性方式进行划分。
  • 应用现状 在自规划磁盘、创建条带逻辑盘等使用场景下,如何在创建节点时,灵活的挂载和划分磁盘成为一个问题。 节点创建中storage字段通过磁盘的大小、磁盘类型等参数的匹配来选择数据盘,避免了盘符匹配失败导致的节点创建、重置、迁移、纳管失败问题(例如当创建节点时NodeExtendParam字段中DockerLVMConfigOverride.diskType参数设置为evs,C7机型的节点会创建失败)。
  • 创建裸盘 在控制台,单击新增数据盘后,在高级配置中默认,则创建磁盘为裸盘。 使用API调用则可以按如下配置。 cceUse selector匹配到一块100G 数据盘。 所选磁盘被cce管理用作数据盘。 dataVolumes中创建的另一块100G 数据盘未被任何selector选中并被group管理。因此此块云盘作为裸盘挂载至节点,不做初始化。 创建后登录节点查看,可以发现有一块100G的盘已经挂载但没有被初始化。 API示例如下: {"kind": "Node","apiVersion": "v3","metadata": {"name": "test-83790"},"spec": {"flavor": "c3.large.2","az": "cn-north-4b","os": "EulerOS 2.9","dataVolumes": [{"size": 100,"volumetype": "SAS"},{"size": 100,"volumetype": "SAS"}],"billingMode": 0,"extendParam": {"maxPods": 110},"nodeNicSpec": {"primaryNic": {"subnetId": "ca964acf-8468-4735-8229-97940ef6c881"}},"rootVolume": {"size": 50,"volumetype": "SAS"},"runtime": {"name": "docker"},"login": {"userPassword": {"username": "root","password": "******"}},"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%"}]}]},"count": 1}}
  • 挂载用户磁盘至指定路径 在控制台,单击新增数据盘后,在高级配置中选择挂载到指定目录,填写指定的磁盘挂载目录,则由CCE实现该磁盘的默认初始化及挂载。 使用API调用则可以按如下配置。 storageSelectors中的user1选中一块100G的数据盘。 通过LVM管理,创建一个名为vguser1的卷组(VG)。 将全部的vguser1空间划分成名叫user的逻辑卷(LV)。并以ext4的文件格式格式化磁盘。最后挂载到/tmp2的目录下。 创建后登录节点查看,可以发现有一块100G的盘已经挂载且被LVM管理。 API示例如下,有两块数据盘,其中一块给CCE使用,另一块挂载到/tmp2目录下。 {"kind": "Node","apiVersion": "v3","metadata": {"name": "test-37106"},"spec": {"flavor": "c3.large.2","az": "cn-north-4b","os": "EulerOS 2.9","dataVolumes": [{"size": 100,"volumetype": "SAS"},{"size": 100,"volumetype": "SAS"}],"billingMode": 0,"extendParam": {"maxPods": 110},"nodeNicSpec": {"primaryNic": {"subnetId": "ca964acf-8468-4735-8229-97940ef6c881"}},"rootVolume": {"size": 50,"volumetype": "SAS"},"runtime": {"name": "docker"},"login": {"userPassword": {"username": "root","password": "******"}},"storage": {"storageSelectors": [{"name": "cceUse","storageType": "evs","matchLabels": {"size": "100","volumeType": "SAS","count": "1"}},{"name": "user1","storageType": "evs","matchLabels": {"size": "100","volumeType": "SAS","count": "1"}}],"storageGroups": [{"name": "vgpaas","selectorNames": ["cceUse"],"cceManaged": true,"virtualSpaces": [{"name": "runtime","size": "80%"},{"name": "kubernetes","size": "20%"}]},{"name": "vguser1","selectorNames": ["user1"],"virtualSpaces": [{"name": "user","size": "100%","lvmConfig": {"lvType": "linear","path": "/tmp2"}}]}]},"count": 1}}
  • 创建条带化逻辑卷,提升磁盘性能 条带化逻辑卷功能当前仅只支持调用API创建,示例如下。 storageSelectors中matchLables为空,则全选evs盘。 通过LVM管理,创建一个名为vgpaas的卷组(VG)。 将90%的vgpaas空间以条带的方式划分成runtime逻辑卷。 将10%的vgpaas空间以条带的方式划分成kubernetes逻辑卷。 需要两块及以上数据盘才能条带化。 创建条带化逻辑卷(LV)时,加入卷组(VG)的物理卷(PV)的类型与大小应尽量保持一致,以免条带化创建失败。 创建后登录节点,使用如下命令可以查看到条带化结果。 API示例如下: { "kind": "Node", "apiVersion": "v3", "metadata": { "name": "test-83773" }, "spec": { "flavor": "c3.large.2", "az": "cn-north-4b", "os": "EulerOS 2.9", "dataVolumes": [ { "size": 100, "volumetype": "SAS" }, { "size": 100, "volumetype": "SAS" } ], "billingMode": 0, "extendParam": { "maxPods": 110 }, "nodeNicSpec": { "primaryNic": { "subnetId": "ca964acf-8468-4735-8229-97940ef6c881" } }, "rootVolume": { "size": 50, "volumetype": "SAS" }, "runtime": { "name": "docker" }, "login": { "userPassword": { "username": "root", "password": "******" } }, "storage": { "storageSelectors": [ { "name": "cceUse", "storageType": "evs" } ], "storageGroups": [ { "name": "vgpaas", "selectorNames": [ "cceUse" ], "cceManaged": true, "virtualSpaces": [ { "name": "runtime", "size": "90%", "runtimeConfig": { "lvType": "striped" } }, { "name": "kubernetes", "size": "10%", "lvmConfig": { "lvType": "striped" } } ] } ] }, "count": 1 }}
  • 集群类型与操作系统对应关系 表3 节点操作系统与集群类型对应表 操作系统 集群版本 VPC网络模型 容器隧道网络模型 云原生网络2.0(CCE Turbo集群) Huawei Cloud EulerOS 2.0 v1.25 √ × √ v1.23 √ × √ Huawei Cloud EulerOS 2.0 (ARM) v1.25 √ × √ v1.23 √ × √ Ubuntu 22.04 1.25 √ × √ 1.23 √ × √ CentOS Linux release 7.6 v1.25 √ √ √ v1.23 √ √ √ v1.21 √ √ √ v1.19.16 √ √ √ v1.19.10 √ √ √ v1.19.8 √ √ √ v1.17.17(停止维护) √ √ √ v1.17.9(停止维护) √ √ √ v1.15.11(停止维护) √ √ √ v1.15.6-r1(停止维护) √ √ √ v1.13.10-r1(停止维护) √ √ √ v1.13.7-r0(停止维护) √ √ √ EulerOS release 2.9 v1.25 √ √ √ v1.23 √ √ √ v1.21 √ √ √ v1.19 √ √ √ EulerOS release 2.9 (ARM) v1.25 √ √ √ v1.23 √ √ √ v1.21 √ √ √ v1.19 √ √ √ EulerOS release 2.10 v1.25 √ √ √ v1.23 √ √ √ EulerOS release 2.10 (ARM) v1.25 √ √ √ v1.23 √ √ √ EulerOS release 2.8(ARM) v1.25 √ √ √ v1.23 √ √ √ v1.21 √ √ √ v1.19.16 √ √ √ v1.19.10 √ √ √ v1.17.17(停止维护) √ √ √ v1.15.11(停止维护) √ √ √ EulerOS release 2.5 v1.25 √ √ √ v1.23 √ √ √ v1.21 √ √ √ v1.19.16 √ √ √ v1.19.10 √ √ √ v1.19.8 √ √ √ v1.17.17(停止维护) √ √ √ v1.17.9(停止维护) √ √ √ v1.15.11(停止维护) √ √ √ v1.15.6-r1(停止维护) √ √ √ v1.13.10-r1(停止维护) √ √ √ v1.13.7-r0(停止维护) √ √ √ Ubuntu 18.04 server 64bit(停止维护) v1.25 √ × √ v1.23 √ × √ v1.21 √ × √ v1.19.16 √ × √ v1.19.8 √ × √ v1.17.17 √ × √ Huawei Cloud EulerOS 1.1 v1.25 √ √ √ v1.23 √ √ √ v1.21 √ √ √
  • 集群版本与操作系统对应关系 如下为当前已经发布的集群版本与操作系统版本的对应关系,请参考: 表1 虚拟机节点操作系统与集群版本对应表 操作系统 集群版本 最新内核信息 Huawei Cloud EulerOS 2.0 v1.25 5.10.0-60.18.0.50.r865_35.hce2.x86_64 v1.23 5.10.0-60.18.0.50.r865_35.hce2.x86_64 Huawei Cloud EulerOS 2.0 (ARM) v1.25 5.10.0-60.18.0.50.r865_35.hce2.aarch64 v1.23 5.10.0-60.18.0.50.r865_35.hce2.aarch64 Ubuntu 22.04 1.25 5.15.0-60-generic 1.23 5.15.0-60-generic CentOS Linux release 7.6 v1.25 3.10.0-1160.66.1.el7.x86_64 v1.23 3.10.0-1160.66.1.el7.x86_64 v1.21 3.10.0-1160.66.1.el7.x86_64 v1.19.16 3.10.0-1160.66.1.el7.x86_64 v1.19.10 3.10.0-1160.25.1.el7.x86_64 v1.19.8 3.10.0-1160.15.2.el7.x86_64 v1.17.17(停止维护) 3.10.0-1160.15.2.el7.x86_64 v1.17.9(停止维护) 3.10.0-1062.12.1.el7.x86_64 v1.15.11(停止维护) 3.10.0-1062.12.1.el7.x86_64 v1.15.6-r1(停止维护) 3.10.0-1062.1.1.el7.x86_64 v1.13.10-r1(停止维护) 3.10.0-957.21.3.el7.x86_64 v1.13.7-r0(停止维护) 3.10.0-957.21.3.el7.x86_64 EulerOS release 2.9 v1.25 4.18.0-147.5.1.6.h841.eulerosv2r9.x86_64 v1.23 4.18.0-147.5.1.6.h841.eulerosv2r9.x86_64 v1.21 4.18.0-147.5.1.6.h841.eulerosv2r9.x86_64 v1.19 4.18.0-147.5.1.6.h841.eulerosv2r9.x86_64 EulerOS release 2.9 (ARM) v1.25 4.19.90-vhulk2103.1.0.h848.eulerosv2r9.aarch64 v1.23 4.19.90-vhulk2103.1.0.h848.eulerosv2r9.aarch64 v1.21 4.19.90-vhulk2103.1.0.h848.eulerosv2r9.aarch64 v1.19 4.19.90-vhulk2103.1.0.h848.eulerosv2r9.aarch64 EulerOS release 2.10 v1.25 4.18.0-147.5.2.10.h933.eulerosv2r10.x86_64 v1.23 4.18.0-147.5.2.10.h933.eulerosv2r10.x86_64 EulerOS release 2.10 (ARM) v1.25 4.19.90-vhulk2204.1.0.h1160.eulerosv2r10.aarch64 v1.23 4.19.90-vhulk2204.1.0.h1160.eulerosv2r10.aarch64 EulerOS release 2.8(ARM) v1.25 4.19.36-vhulk1907.1.0.h1350.eulerosv2r8.aarch64 v1.23 4.19.36-vhulk1907.1.0.h1350.eulerosv2r8.aarch64 v1.21 4.19.36-vhulk1907.1.0.h1350.eulerosv2r8.aarch64 v1.19.16 4.19.36-vhulk1907.1.0.h1350.eulerosv2r8.aarch64 v1.19.10 4.19.36-vhulk1907.1.0.h962.eulerosv2r8.aarch64 v1.17.17(停止维护) 4.19.36-vhulk1907.1.0.h962.eulerosv2r8.aarch64 v1.15.11(停止维护) 4.19.36-vhulk1907.1.0.h702.eulerosv2r8.aarch64 EulerOS release 2.5 v1.25 3.10.0-862.14.1.5.h687.eulerosv2r7.x86_64 v1.23 3.10.0-862.14.1.5.h687.eulerosv2r7.x86_64 v1.21 3.10.0-862.14.1.5.h687.eulerosv2r7.x86_64 v1.19.16 3.10.0-862.14.1.5.h687.eulerosv2r7.x86_64 v1.19.10 3.10.0-862.14.1.5.h520.eulerosv2r7.x86_64 v1.19.8 3.10.0-862.14.1.5.h520.eulerosv2r7.x86_64 v1.17.17(停止维护) 3.10.0-862.14.1.5.h470.eulerosv2r7.x86_64 v1.17.9(停止维护) 3.10.0-862.14.1.5.h428.eulerosv2r7.x86_64 v1.15.11(停止维护) 3.10.0-862.14.1.5.h428.eulerosv2r7.x86_64 v1.15.6-r1(停止维护) 3.10.0-862.14.1.5.h328.eulerosv2r7.x86_64 v1.13.10-r1(停止维护) 3.10.0-862.14.1.2.h249.eulerosv2r7.x86_64 v1.13.7-r0(停止维护) 3.10.0-862.14.1.0.h197.eulerosv2r7.x86_64 Ubuntu 18.04 server 64bit(停止维护) v1.25 4.15.0-171-generic v1.23 4.15.0-171-generic v1.21 4.15.0-171-generic v1.19.16 4.15.0-171-generic v1.19.8 4.15.0-136-generic v1.17.17 4.15.0-136-generic Huawei Cloud EulerOS 1.1 v1.25 3.10.0-1160.66.1.hce1c.x86_64 v1.23 3.10.0-1160.66.1.hce1c.x86_64 v1.21 3.10.0-1160.66.1.hce1c.x86_64 表2 裸金属节点操作系统与集群版本对应表 操作系统 集群版本 内核信息 EulerOS release 2.10(弹性裸金属服务器) v1.25 v1.23 v1.21 v1.19.16 4.18.0-147.5.2.15.h1109.eulerosv2r10.x86_64 EulerOS release 2.9(裸金属服务器) v1.25 v1.23 v1.21 v1.19 4.18.0-147.5.1.6.h841.eulerosv2r9.x86_64 该服务器的规格信息请参见裸金属服务器实例家族。 EulerOS release 2.3(裸金属服务器)(停止维护) v1.15.11以上 3.10.0-514.41.4.28.h62.x86_64 该服务器的规格信息请参见裸金属服务器实例家族。
  • 响应消息体 响应消息体通常以结构化格式返回,与响应消息头中Content-type对应,传递除响应消息头之外的内容。 对于获取用户Token接口,返回如下消息体。为篇幅起见,这里只展示部分内容。 { "token": { "expires_at": "2019-02-13T06:52:13.855000Z", "methods": [ "password" ], "catalog": [ { "endpoints": [ { "region_id": "cn-north-4",...... 当接口调用出错时,会返回错误码及错误信息说明,错误响应的Body体格式如下所示。 { "error_msg": "The format of message is error", "error_code": "AS.0001"} 其中,error_code表示错误码 ,error_msg表示错误描述信息。
  • 终端节点(Endpoint) 终端节点(Endpoint)即调用API的请求地址,不同服务不同区域的终端节点不同,您可以从地区和终端节点查询服务的终端节点。 请您根据业务需要选择对应区域的终端节点。 集群管理、节点管理、节点池管理、插件管理、配额管理的URL格式为:https://Endpoint/uri。其中uri为资源路径,也即API访问的路径。 Kubernetes API、存储管理的URL格式为:https://{clusterid}.Endpoint/uri。其中{clusterid}为集群ID,uri为资源路径,也即API访问的路径。 表1 URL中的参数说明 参数 描述 {clusterid} 集群ID,创建集群后,调用获取指定项目下的集群接口获取。 Endpoint Web服务入口点的URL,不同服务不同区域的终端节点不同。 uri 资源路径,也即API访问路径。从具体接口的URI模块获取,例如“获取用户Token”API的resource-path为“v3/auth/tokens”。 父主题: 使用前必读
  • 请求示例 更新everest插件,更新后的插件版本为2.1.30。 { "kind" : "Addon", "apiVersion" : "v3", "metadata" : { "annotations" : { "addon.upgrade/type" : "upgrade" } }, "spec" : { "clusterID" : "*****", "version" : "2.1.30", "addonTemplateName" : "everest", "values" : { "basic" : { "bms_url" : "*****", "driver_init_image_version" : "2.1.30", "ecsEndpoint" : "*****", "everest_image_version" : "2.1.30", "evs_url" : "*****", "iam_url" : "*****", "ims_url" : "*****", "obs_url" : "*****", "platform" : "linux-amd64", "sfs30_url" : "*****", "sfs_turbo_url" : "*****", "sfs_url" : "*****", "supportHcs" : false, "swr_addr" : "*****", "swr_user" : "hwofficial", "rbac_enabled" : true, "cluster_version" : "v1.23" }, "flavor" : { "description" : "High avaiable", "name" : "HA", "replicas" : 2, "resources" : [ { "limitsCpu" : "250m", "limitsMem" : "2000Mi", "name" : "everest-csi-controller", "requestsCpu" : "250m", "requestsMem" : "1500Mi" }, { "limitsCpu" : "500m", "limitsMem" : "300Mi", "name" : "everest-csi-driver", "requestsCpu" : "100m", "requestsMem" : "300Mi" } ], "category" : [ "CCE", "Turbo" ] }, "custom" : { "cluster_id" : "*****", "csi_attacher_detach_worker_threads" : "60", "csi_attacher_worker_threads" : "60", "default_vpc_id" : "*****", "disable_auto_mount_secret" : false, "enable_node_attacher" : true, "flow_control" : { }, "multiAZEnabled" : false, "over_subscription" : "80", "project_id" : "*****", "volume_attaching_flow_ctrl" : "0" } } }}
  • 响应示例 状态码: 200 OK { "kind" : "Addon", "apiVersion" : "v3", "metadata" : { "uid" : "684fa9b2-a987-11ec-ba79-0255ac100096", "name" : "gpu-beta", "alias" : "gpu", "creationTimestamp" : "2022-03-22T02:25:57Z", "updateTimestamp" : "2022-03-22T02:25:57Z" }, "spec" : { "clusterID" : "1b2ec02d-a3b2-11ec-b0d0-0255ac100099", "version" : "1.2.10", "addonTemplateName" : "gpu-beta", "addonTemplateType" : "helm", "addonTemplateLogo" : "******", "addonTemplateLabels" : [ "Accelerator" ], "description" : "A device plugin for nvidia.com/gpu resource on nvidia driver", "values" : { "basic" : { "device_version" : "1.2.10", "driver_version" : "1.2.10", "obs_url" : "******", "rbac_enabled" : true, "region" : "******", "swr_addr" : "******", "swr_user" : "hwofficial" }, "custom" : { "is_driver_from_nvidia" : true, "nvidia_driver_download_url" : "https://us.download.nvidia.com/tesla/396.37/NVIDIA-Linux-x86_64-396.37.run" } } }, "status" : { "status" : "upgrading", "Reason" : "addon upgrading", "message" : "", "targetVersions" : null, "currentVersion" : { "version" : "1.2.10", "input" : { "basic" : { "device_version" : "1.2.10", "driver_version" : "1.2.10", "obs_url" : "******", "region" : "******", "swr_addr" : "******", "swr_user" : "hwofficial" }, "parameters" : { "custom" : { "is_driver_from_nvidia" : true, "nvidia_driver_download_url" : "" } } }, "stable" : true, "translate" : { "en_US" : { "addon" : { "changeLog" : "Supported GPU driver of a new version for CentOS.", "description" : "A device plugin for nvidia.com/gpu resource on nvidia driver" }, "description" : { "Parameters.custom.drivers_info.cuda" : "CUDA Toolkit", "Parameters.custom.drivers_info.product" : "Product", "Parameters.custom.drivers_info.product_series" : "Product Series", "Parameters.custom.drivers_info.product_type" : "Product Type", "Parameters.custom.nvidia_driver_download_url" : "Download the nvidia driver accroding to the input link" }, "key" : { "Parameters.custom.nvidia_driver_download_url" : "Nvidia Driver" } }, "fr_FR" : { "addon" : { "changeLog" : "Pilote GPU pris en charge d'une nouvelle version pour CentOS.", "description" : "Un plug-in de dispositif pour les ressources GPU sur un pilote NVIDIA." }, "description" : { "Parameters.custom.drivers_info.cuda" : "Boîte à outils CUDA", "Parameters.custom.drivers_info.product" : "Produit", "Parameters.custom.drivers_info.product_series" : "Serie de produits", "Parameters.custom.drivers_info.product_type" : "type de produit", "Parameters.custom.nvidia_driver_download_url" : "Téléchargez le pilote nvidia accroding sur le lien d'entrée" }, "key" : { "Parameters.custom.nvidia_driver_download_url" : "Nvidia Driver" } }, "zh_CN" : { "addon" : { "changeLog" : "", "description" : "" }, "description" : { "Parameters.custom.drivers_info.cuda" : "CUDA Toolkit", "Parameters.custom.drivers_info.product" : "", "Parameters.custom.drivers_info.product_series" : "", "Parameters.custom.drivers_info.product_type" : "", "Parameters.custom.nvidia_driver_download_url" : "" }, "key" : { "Parameters.custom.nvidia_driver_download_url" : "" } } }, "supportVersions" : null, "creationTimestamp" : "2022-01-11T14:57:44Z", "updateTimestamp" : "2022-01-11T15:04:37Z" } }}
  • 概述 欢迎使用云容器引擎(Cloud Container Engine,简称CCE)。云容器引擎提供高度可扩展的、高性能的企业级Kubernetes集群,支持运行Docker容器。借助云容器引擎,您可以在云上轻松部署、管理和扩展容器化应用程序。 您可以使用本文档提供API对云容器引擎进行相关操作,如创建、删除、变更规格、添加网卡等。支持的全部操作请参见2 API概览。 在调用云容器引擎API之前,请确保已经充分了解云容器引擎相关概念,详细信息请参见产品介绍。 另外,云容器引擎所提供的接口分为CCE接口与Kubernetes原生接口。通过配合使用,您可以完整的使用云容器引擎的所有功能。 Kubernetes相关概念请参见Kubernetes基础知识。 Kubernetes原生接口版本级别的相关概念请参见https://kubernetes.io/docs/concepts/overview/kubernetes-api/。 此外: 当前版本调用Kubernetes接口不支持HTTP长链接。 当前版本调用的Kubernetes接口包含Beta级别的接口,即版本名称包含了beta (例如: v1beta1)的接口。此类接口会根据Kubernetes原生接口的变化而变化,因此推荐在非重要的情况下使用,例如短期测试集群等。 使用kubectl或SDK等,非本指导书中提供的方法调用接口,不能保证调用后接口功能正常,因此请按照本指导书中的方法调用接口。 本文档提供了云容器引擎(Cloud Container Engine,简称CCE)API的描述、语法、参数说明及样例等内容。您可以根据表1查找您需要的内容。 表1 文档导读 章节 说明 接口简介 了解CCE接口组成及接口列表。 环境准备 了解使用接口前的必须准备工作,包括创建VPC、获取请求证书等。 接口使用方法 了解REST API消息体组成、调用方法及示例。 API CCE提供的API接口,包含集群管理、存储管理、Secret等。 公共参数 包含CCE接口用到的公共参数、状态码、错误码等内容。 父主题: 使用前必读
  • 请求示例 {"metadata": {"annotations": {"addon.install/type": "install"}},"spec": {"clusterID": "ccbe7bdf-4**9-3**b-b**4-0********78","version": "1.0.3","addonTemplateName": "virtual-kubelet","values": {"basic": {"available_zone": "cn-north-4a","cci_address": "https://cci.cn-north-4.myhuaweicloud.com:443","euleros_version": "2.2.5","iam_address": "https://iam.cn-north-4.myhuaweicloud.com:443","swr_addr": "swr.cn-north-4.myhuaweicloud.com","swr_user": "hwofficial","rbac_enabled": true,"cluster_id": "ccbe7bdf-4**9-3**b-b**4-0********78","cluster_name": "test-vk","vpc_id": "2372199f-e6e0-48be-9437-e774aae6bd70","network_id": "863a5e6c-e4f5-45f8-80d9-5090f17a767b","security_group_id": "ac3c1a82-f320-495a-b81d-e7aaa6b304a4","project_id": "085a4*********00a9ccf7fba","region": "cn-north-4"},"flavor": {"description": "Redundancy backup is not available for the add-on.","name": "Single-instance","replicas": 1,"resources": [{"limitsCpu": "250m","limitsMem": "512Mi","name": "virtual-kubelet","requestsCpu": "250m","requestsMem": "512Mi"}]},"custom": {"isInstallProxy": true}}}}
  • 字段说明 表1 参数描述 参数 是否必选 参数类型 描述 basic 是 表2 object 插件基础配置参数 flavor 是 表3 object 插件规格参数 custom 是 表4 object 插件自定义参数 表2 basic 参数 是否必选 参数类型 描述 available_zone 是 String 插件所在可用区。 如:cn-north-4a cci_address 是 String CCI的访问地址和端口。 如:https://cci.cn-north-4.myhuaweicloud.com:443 euleros_version 是 String 欧拉OS的版本,固定为:2.2.5 iam_address 是 String IAM的访问地址和端口。 如:https://iam.cn-north-4.myhuaweicloud.com:443 swr_addr 是 String SWR的访问地址。 如:swr.cn-north-4.myhuaweicloud.com swr_user 是 String SWR的用户名,官方插件默认为:hwofficial rbac_enabled 是 String 是否支持RBAC,支持则值为:true cluster_id 是 String 集群ID cluster_name 是 String 集群的名称 vpc_id 是 String 虚拟私有云ID network_id 是 String 子网ID security_group_id 是 String 安全组ID project_id 是 String 项目ID region 是 String 所在区域。 如:cn-north-4 表3 flavor 参数 是否必选 参数类型 描述 description 否 String 插件相关的描述信息 name 是 String 插件规格名称,固定为:Single-instance replicas 是 String 实例数,默认为:1 resources 是 resources object 容器资源(CPU、内存)配额。 表4 custom 参数 是否必选 参数类型 描述 isInstallProxy 否 String 跨服务互通。 true:支持CCE集群中的Pod与CCI集群中的Pod通过Kubernetes Service互通。 表5 resources字段数据结构说明 参数 是否必选 参数类型 描述 limitsCpu 是 String CPU大小限制,单位:m 默认为:250m limitsMem 是 String 内存大小限制,单位:Mi 默认为:512Mi name 是 String 插件名称,固定为:virtual-kubelet requestsCpu 是 String 申请的CPU大小,单位:m 默认为:250m requestsMem 是 String 申请的内存大小,单位:Mi 默认为:512Mi
  • 响应示例 状态码: 200 ok { "kind" : "Addon", "apiVersion" : "v3", "items" : [ { "kind" : "Addon", "apiVersion" : "v3", "metadata" : { "uid" : "8ca259cc-553b-11e9-926f-0255ac101a31", "name" : "storage-driver", "alias" : "storage-driver", "creationTimestamp" : "2019-04-02T11:36:26Z", "updateTimestamp" : "2019-04-02T11:36:26Z" }, "spec" : { "clusterID" : "0c0e4a63-5539-11e9-95f7-0255ac10177e", "version" : "1.0.10", "addonTemplateName" : "storage-driver", "addonTemplateType" : "helm", "addonTemplateLogo" : "https://192.149.48.66/cce-addon-southchina-aw1hz2u/storage-driverlogo.svg", "addonTemplateLabels" : [ "Storage" ], "description" : "A kubernetes FlexVolume Driver used to support cloud storage", "values" : { "basic" : { "addon_version" : "1.0.10", "euleros_version" : "2.2.5", "obs_url" : "", "platform" : "linux-amd64", "swr_addr" : "100.125.6.246:20202", "swr_user" : "hwofficial" }, "flavor" : { "replicas" : 1 }, "parameters" : { } } }, "status" : { "status" : "running", "Reason" : "Install complete", "message" : "", "targetVersions" : null, "currentVersion" : { "version" : "1.0.10", "input" : { "basic" : { "euleros_version" : "2.2.5", "obs_url" : "", "swr_addr" : "100.125.6.246:20202", "swr_user" : "hwofficial" }, "parameters" : { } }, "stable" : true, "translate" : { "en_US" : { "addon" : { "changeLog" : "The plug-in is upgraded to enhance the storage plug-in function.", "description" : "A kubernetes FlexVolume Driver used to support cloud storage" } }, "zh_CN" : { "addon" : { "changeLog" : "", "description" : "" } } }, "supportVersions" : null, "creationTimestamp" : "2019-03-29T13:45:37Z", "updateTimestamp" : "2019-03-29T13:45:37Z" } } } ]}
  • 响应示例 状态码: 201 OK { "kind" : "Addon", "apiVersion" : "v3", "metadata" : { "uid" : "b748aaea-a984-11ec-987b-0255ac1000bc", "name" : "coredns", "alias" : "coredns", "creationTimestamp" : "2022-03-22T02:06:41Z", "updateTimestamp" : "2022-03-22T02:06:41Z" }, "spec" : { "clusterID" : "1b2ec02d-a3b2-11ec-b0d0-0255ac100099", "version" : "1.17.15", "addonTemplateName" : "coredns", "addonTemplateType" : "helm", "addonTemplateLogo" : "", "addonTemplateLabels" : [ "ServiceDiscovery" ], "description" : "CoreDNS is a DNS server that chains plugins and provides Kubernetes DNS Services", "values" : { "basic" : { "cluster_ip" : "10.247.3.10", "image_version" : "1.17.15", "platform" : "linux-amd64", "rbac_enabled" : true, "swr_addr" : "", "swr_user" : "hwofficial" }, "custom" : { "cluster_id" : "1b2ec02d-a3b2-11ec-b0d0-0255ac100099", "stub_domains" : { }, "tenant_id" : "0504201b6c80256b2f08c0099f0c8fe4", "upstream_nameservers" : [ ] }, "flavor" : { "name" : 2500, "replicas" : 2, "resources" : [ { "limitsCpu" : "500m", "limitsMem" : "512Mi", "name" : "coredns", "requestsCpu" : "500m", "requestsMem" : "512Mi" } ] } } }, "status" : { "status" : "installing", "Reason" : "", "message" : "", "targetVersions" : null, "currentVersion" : { "version" : "1.17.15", "input" : { "basic" : { "cluster_ip" : "10.247.3.10", "image_version" : "1.17.15", "platform" : "linux-amd64", "swr_addr" : "", "swr_user" : "hwofficial" }, "parameters" : { "custom" : { "stub_domains" : "", "upstream_nameservers" : "" }, "flavor1" : { "name" : 2500, "replicas" : 2, "resources" : [ { "limitsCpu" : "500m", "limitsMem" : "512Mi", "name" : "coredns", "requestsCpu" : "500m", "requestsMem" : "512Mi" } ] }, "flavor2" : { "name" : 5000, "replicas" : 2, "resources" : [ { "limitsCpu" : "1000m", "limitsMem" : "1024Mi", "name" : "coredns", "requestsCpu" : "1000m", "requestsMem" : "1024Mi" } ] }, "flavor3" : { "name" : 10000, "replicas" : 2, "resources" : [ { "limitsCpu" : "2000m", "limitsMem" : "2048Mi", "name" : "coredns", "requestsCpu" : "2000m", "requestsMem" : "2048Mi" } ] }, "flavor4" : { "name" : 20000, "replicas" : 4, "resources" : [ { "limitsCpu" : "2000m", "limitsMem" : "2048Mi", "name" : "coredns", "requestsCpu" : "2000m", "requestsMem" : "2048Mi" } ] } } }, "stable" : true, "translate" : { "en_US" : { "addon" : { "changeLog" : "Supported CCE clusters of v1.21.", "description" : "CoreDNS is a DNS server that chains plugins and provides Kubernetes DNS Services" }, "description" : { "Parameters.custom.stub_domains" : "The target nameserver may itself be a Kubernetes service. For instance, you can run your own copy of dnsmasq to export custom DNS names into the ClusterDNS namespace, a JSON map using a DNS suffix key (e.g. “acme.local”) and a value consisting of a JSON array of DNS IPs.", "Parameters.custom.upstream_nameservers" : "If specified, then the values specified replace the nameservers taken by default from the node’s /etc/resolv.conf. Limits:a maximum of three upstream nameservers can be specified, A JSON array of DNS IPs.", "Parameters.flavor1.description" : "Concurrent domain name resolution ability - External domain name:2500 qps, Internal domain name:10000 qps", "Parameters.flavor1.name" : 2500, "Parameters.flavor2.description" : "Concurrent domain name resolution ability - External domain name:5000 qps, Internal domain name:20000 qps", "Parameters.flavor2.name" : 5000, "Parameters.flavor3.description" : "Concurrent domain name resolution ability - External domain name:10000 qps, Internal domain name:40000 qps", "Parameters.flavor3.name" : 10000, "Parameters.flavor4.description" : "Concurrent domain name resolution ability - External domain name:20000 qps, Internal domain name:80000 qps", "Parameters.flavor4.name" : 20000 }, "key" : { "Parameters.custom.stub_domains" : "stub domain", "Parameters.custom.upstream_nameservers" : "upstream nameservers" } }, "fr_FR" : { "addon" : { "changeLog" : "Prise en charge du cluster 1.21.", "description" : "Un serveur DNS qui enchaîne les plug-ins et fournit des services DNS Kubernetes." }, "description" : { "Parameters.custom.stub_domains" : "Le serveur de noms cible peut lui-même être un service Kubernetes. Par exemple, vous pouvez exécuter votre propre copie de dnsmasq pour exporter des noms DNS personnalisés dans l'espace de noms ClusterDNS, une carte JSON à l'aide d'une clé de suffixe DNS (par exemple, «acme.local») et une valeur constituée d'un tableau JSON d'adresses IP DNS.", "Parameters.custom.upstream_nameservers" : "Si spécifié, les valeurs spécifiées remplacent les serveurs de noms pris par défaut dans le fichier /etc/resolv.conf du nœud. Limites: un maximum de trois serveurs de noms en amont peuvent être spécifiés, un tableau JSON d'adresses IP DNS.", "Parameters.flavor1.description" : "Capacité de résolution de nom de domaine simultanée - Nom de domaine externe: 2500 qps, Nom de domaine interne: 10000 qp", "Parameters.flavor1.name" : 2500, "Parameters.flavor2.description" : "Capacité de résolution de nom de domaine simultanée - Nom de domaine externe: 5000 qps, Nom de domaine interne: 20000 qp", "Parameters.flavor2.name" : 5000, "Parameters.flavor3.description" : "Capacité de résolution de nom de domaine simultanée - Nom de domaine externe: 10000 qps, Nom de domaine interne: 40000 qp", "Parameters.flavor3.name" : 10000, "Parameters.flavor4.description" : "Capacité de résolution de nom de domaine simultanée - Nom de domaine externe: 20000 qps, Nom de domaine interne: 80000 qp", "Parameters.flavor4.name" : 20000 }, "key" : { "Parameters.custom.stub_domains" : "domaine stub", "Parameters.custom.upstream_nameservers" : "serveurs de noms en amont" } }, "zh_CN" : { "addon" : { "changeLog" : "", "description" : "" }, "description" : { "Parameters.custom.stub_domains" : "", "Parameters.custom.upstream_nameservers" : "", "Parameters.flavor1.description" : "", "Parameters.flavor1.name" : 2500, "Parameters.flavor2.description" : "", "Parameters.flavor2.name" : 5000, "Parameters.flavor3.description" : "", "Parameters.flavor3.name" : 10000, "Parameters.flavor4.description" : "", "Parameters.flavor4.name" : 20000 }, "key" : { "Parameters.custom.stub_domains" : "", "Parameters.custom.upstream_nameservers" : "" } } }, "supportVersions" : null, "creationTimestamp" : "2021-12-14T13:43:15Z", "updateTimestamp" : "2022-01-11T14:32:10Z" } }}
  • 响应示例 状态码: 200 OK { "kind" : "Addon", "apiVersion" : "v3", "metadata" : { "uid" : "24b23108-55c0-11e9-926f-0255ac101a31", "name" : "gpu-beta", "alias" : "gpu", "creationTimestamp" : "2019-04-03T03:25:34Z", "updateTimestamp" : "2019-04-03T03:25:34Z" }, "spec" : { "clusterID" : "0c0e4a63-5539-11e9-95f7-0255ac10177e", "version" : "1.0.0", "addonTemplateName" : "gpu-beta", "addonTemplateType" : "helm", "addonTemplateLogo" : "", "addonTemplateLabels" : [ "Accelerator" ], "description" : "A device plugin for nvidia.com/gpu resource on nvidia driver", "values" : { "basic" : { "rbac_enabled" : true, "swr_addr" : "100.125.6.246:20202", "swr_user" : "hwofficial" } } }, "status" : { "status" : "installing", "Reason" : "", "message" : "", "targetVersions" : null, "currentVersion" : { "version" : "1.0.0", "input" : { "basic" : { "swr_addr" : "100.125.6.246:20202", "swr_user" : "hwofficial" }, "parameters" : { } }, "stable" : true, "translate" : { "en_US" : { "addon" : { "changeLog" : "A device plugin for nvidia.com/gpu resource on nvidia driver", "description" : "A device plugin for nvidia.com/gpu resource on nvidia driver" } }, "zh_CN" : { "addon" : { "changeLog" : "", "description" : "" } } }, "supportVersions" : null, "creationTimestamp" : "2018-10-23T13:14:55Z", "updateTimestamp" : "2018-12-07T09:40:24Z" } }}
  • 节点最大实例数 在创建节点时,可以配置节点可以创建的最大实例数(maxPods)。该参数是kubelet的配置参数,决定kubelet最多可创建多少个Pod。 对于默认节点池(DefaultPool)中的节点,节点创建完成后,最大实例数不支持修改。 对于自定义节点池中的节点,创建完成后可通过修改节点池配置中的max-pods参数,修改节点最大实例数。 图2 节点最大实例数配置 根据节点规格不同,节点默认最大实例数如表1所示。 表1 节点默认最大实例数 内存 节点默认最大实例数 4G 20 8G 40 16G 60 32G 80 64G及以上 110
  • 容器网络 vs 主机网络 创建Pod时,可以选择Pod使用容器网络或是宿主机网络。 容器网络:默认使用容器网络,Pod的网络由集群网络插件负责分配,每个Pod分配一个IP地址,会占用容器网络的IP。 主机网络:Pod直接使用宿主机的网络(Pod需要配置hostNetwork: true),会占用宿主机的端口,Pod的IP就是宿主机的IP,不会占用容器网络的IP。使用时需要考虑是否与宿主机上的端口冲突,因此一般情况下除非您知道需要某个特定应用占用宿主机上的特定端口时,不建议使用主机网络。
共100000条