配置资源规整时忽略特定容器
本文介绍如何为特定容器(例如Sidecar容器)设置环境变量,实现ECI资源规整时忽略该容器,以避免资源浪费,节约ECI使用成本。
功能说明
指定vCPU和内存创建ECI实例时,您可以自定义指定每个容器的vCPU和内存,但汇总到实例级别时,需满足ECI实例整体的vCPU和内存约束。如果实例级别没有配置vCPU和内存,则会汇总计算所有容器的规格之和,对于总和不满足ECI规格的情况,系统会自动进行资源规整。

一般情况下,容器内指定的vCPU和内存为容器资源上限,实际运行实例时,系统会动态调整资源分配。因此对于实例内一些不影响业务的特定容器,您可以通过设置环境变量_ECI_RESOURCE_IGNORE_:TRUE
的方式,实现实例资源规整时忽略这些容器,避免资源规整后创建的实例规格过大,出现资源浪费。
示例如下:

如上图所示,假设一个ECI实例包含3个容器,容器1和2(业务容器)均配置为2 vCPU、4 GiB内存,容器3(Sidecar容器)配置为0.25 vCPU、0.5 GiB内存。一般情况下,系统会自动将实例规格规整到8 vCPU、16GiB内存。但实际情况下可能并不需要8 vCPU、16GiB的资源,在不影响业务的基础上,您可以为Sidecar容器设置环境变量__ECI_RESOURCE_IGNORE__:TRUE
。配置后,系统会忽略Sidecar容器,将实例规格规整到4 vCPU、8GiB内存。
配置说明
为ECI Pod内的容器设置以下环境变量可以配置ECI资源规整忽略该容器:
env:
- name: "__ECI_RESOURCE_IGNORE__"
value: "TRUE"
完整YAML配置示例如下:
apiVersion: apps/v1
kind: Deployment
metadata:
name: test
labels:
app: test
spec:
replicas: 2
selector:
matchLabels:
app: nginx
template:
metadata:
name: nginx-test
labels:
app: nginx
alibabacloud.com/eci: "true"
spec:
containers:
- name: nginx1
image: registry.cn-shanghai.aliyuncs.com/eci_open/nginx:1.14.2
resources:
limits:
cpu: "2000m"
memory: "4096Mi"
- name: nginx2
image: registry.cn-shanghai.aliyuncs.com/eci_open/nginx:1.14.2
resources:
limits:
cpu: "1000m"
memory: "2048Mi"
env:
- name: "__ECI_RESOURCE_IGNORE__"
value: "TRUE"
restartPolicy: Always
按上述YAML创建Deployment,每个ECI Pod的规格为2 vCPU、4 GiB内存,即采用nginx1容器的limit配置,忽略nginx2的limit配置。