在 Kubernetes (k8s) 中,资源请求和限制用于管理容器的 CPU 和内存资源。配置 CPU 和内存资源时,使用特定的单位来表示资源的数量。
m
表示毫核 (millicores)。1 核心等于 1000 毫核。因此,配置 cpu: 500m
表示请求或限制 0.5 个 CPU 核心。
Ki
:Kibibytes (1024 bytes)Mi
:Mebibytes (1024 Kibibytes)Gi
:Gibibytes (1024 Mebibytes)因此,配置 memory: 500Mi
表示请求或限制 500 Mebibytes 的内存。
以下是一个示例 Pod 配置文件,展示了如何配置 CPU 和内存资源:
apiVersion: v1 kind: Pod metadata: name: example-pod spec: containers: - name: example-container image: nginx resources: requests: memory: "500Mi" cpu: "500m" limits: memory: "1Gi" cpu: "1"
requests:表示容器启动时所需的最小资源量。调度器会根据请求的资源量来决定将 Pod 调度到哪个节点。
memory: "500Mi"
:请求 500 Mebibytes 的内存。cpu: "500m"
:请求 0.5 个 CPU 核心。limits:表示容器可以使用的最大资源量。如果容器超出这个限制,可能会被杀死或限制其资源使用。
memory: "1Gi"
:限制容器最多使用 1 Gibibyte 的内存。cpu: "1"
:限制容器最多使用 1 个 CPU 核心。500m
表示 0.5 个 CPU 核心。500Mi
表示 500 Mebibytes 的内存。通过配置资源请求和限制,可以更好地管理和优化 Kubernetes 集群中的资源使用,确保应用程序的稳定性和性能。