You need to enable JavaScript to run this app.
导航
指定容器 vCPU 和内存创建通用型实例
最近更新时间:2024.12.27 17:14:28首次发布时间:2021.11.04 14:08:18

弹性容器实例支持通过特定 Annotation 指定实例规格族和子网,同时指定容器 vCPU 和内存方式创建通用型实例。

使用限制

  • 通用型 中每个规格族支持的地域和可用区不同,详情请参见 地域和可用区
  • 每个容器的规格可以自定义配置,但汇总到实例级别时需满足 VCI 实例的 vCPU 和内存约束。
    对于不满足的情况,系统会进行自动规整,并按规整后的规格进行计费。规整逻辑,请参见本文下方 Pod 规格计算方式

前提条件

Kubernetes 方式创建

您可以直接定义对应 Container 的 request、limit 来指定该容器的 vCPU 和内存。同时,您也可以通过添加 Annotation,指定规格族创建 VCI 实例。指定规格族相应 Annotation 说明,如下所示。

Annotation KeyAnnotation Value 示例值说明是否必填

vci.vke.volcengine.com/preferred-instance-family

vci.u1

通用型 中的实例 规格族

说明

  • 若不指定该 Annotation,则使用 VCI 指定的默认规格族vci.u1
  • 该 Annotation 的 GPU 计算型 取值说明,请参见 指定容器 GPU 资源创建 GPU 计算型实例
  • 按照匹配的实例规格计费。计费说明,请参见 产品计费
  • 支持指定多个规格族(Annotation Value),多个规格族之间以半角逗号(,)分隔,并按照前后顺序排列优先级。

非必填

以创建无状态负载(Deployment)为例,完整的示例代码如下所示:

说明

更多 Annotation 相关说明,请参见 Pod Annotation 说明

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 2
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      annotations:
        vke.volcengine.com/burst-to-vci: enforce  #强制使用 VCI
        vke.volcengine.com/preferred-subnet-ids: subnet-3tispp1nai**** #指定子网 ID,可指定同一个可用区内多个子网,多个子网之间用半角逗号(,)分隔
        vci.vke.volcengine.com/preferred-instance-family: vci.u1 #指定 VCI 的规格族
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: cr-cn-beijing.volces.com/tw/nginx:1.0 # 容器镜像的地址和版本,请配置为您自己的镜像地址
        ports:
        - containerPort: 80
        resources:
          requests:  #指定容器的 vCPU 和内存  
            cpu: "500m"      
            memory: "1024Mi"
          limits:
            cpu: "1"      
            memory: "2048Mi"

控制台方式创建

在 VPC-CNI 集群中 创建工作负载 时,配置以下参数:

  1. 配置 基本信息 时:算力类型 选择 弹性容器实例 VCI
    alt
  2. 配置 容器配置 时:资源配额 处,按需设置 CPU、内存请求和上限。
    alt
  3. 配置 高级配置 时:VCI 规格配置 处,配置实例规格。
    alt

Pod 规格计算方式

指定容器 vCPU 和内存创建实例时的 Pod 规格计算方式如下所示:

  1. 分别计算 Pod 的 CPU、内存的上限合计数值:

    • CPU 合计数值 = Pod 内 所有 Init 容器的 CPU 上限最大值所有应用容器的 CPU 上限之和 两者中,数值较大者。

      说明

      如果某个 Init/应用容器没有配置 CPU 上限,则该容器按 CPU 请求值计算。

    • 内存合计数值 = Pod 内 所有 Init 容器的内存上限最大值所有应用容器的内存上限之和 两者中,数值较大者。

      说明

      如果某个 Init/应用容器没有配置内存上限,则该容器按内存请求值计算。

    • 若 Pod 内某个容器同时未设置内存的上限和请求,或者 CPU 的上限和请求,则该项的数值以 0 计算。
  2. 根据合计数值,系统自动规整 Pod 规格,且按自动规整后的实例规格计费。规整方法如下所示:

    合计数值计算方法

    CPU 合计数值 = 0

    内存合计数值 = 0

    默认使用 2 核 4 GiB 实例规格。

    CPU 合计数值 = 0;内存合计数值 != 0

    CPU 合计数值 != 0;内存合计数值 = 0

    1. 先匹配非 0 项,并按照该项的规格,选择与之一致或者相近的较大实例规格。

      若超出非 0 项的最大规格,则创建实例失败。

    2. 再匹配 0 项,选择大于 0 的相近实例规格。

    CPU 合计数值 != 0

    内存合计数值 != 0

    1. 先匹配 CPU 合计数值,选择一致或相近的较大实例规格。

      如超出最大 CPU 规格,则创建实例失败。

    2. 再匹配内存合计数值,选择一致或相近的较大实例规格。

      如超出该 CPU 支持的最大内存规格,则创建实例失败。