W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
本章介紹如何為命名空間配置默認(rèn)的內(nèi)存請(qǐng)求和限制。
一個(gè) Kubernetes 集群可被劃分為多個(gè)命名空間。 如果你在具有默認(rèn)內(nèi)存限制 的命名空間內(nèi)嘗試創(chuàng)建一個(gè) Pod,并且這個(gè) Pod 中的容器沒(méi)有聲明自己的內(nèi)存資源限制, 那么控制面會(huì)為該容器設(shè)定默認(rèn)的內(nèi)存限制。
Kubernetes 還為某些情況指定了默認(rèn)的內(nèi)存請(qǐng)求,本章后面會(huì)進(jìn)行介紹。
你必須擁有一個(gè) Kubernetes 的集群,同時(shí)你的 Kubernetes 集群必須帶有 kubectl 命令行工具。 建議在至少有兩個(gè)節(jié)點(diǎn)的集群上運(yùn)行本教程,且這些節(jié)點(diǎn)不作為控制平面主機(jī)。 如果你還沒(méi)有集群,你可以通過(guò) Minikube 構(gòu)建一個(gè)你自己的集群,或者你可以使用下面任意一個(gè) Kubernetes 工具構(gòu)建:
在你的集群里你必須要有創(chuàng)建命名空間的權(quán)限。
你的集群中的每個(gè)節(jié)點(diǎn)必須至少有 2 GiB 的內(nèi)存。
創(chuàng)建一個(gè)命名空間,以便本練習(xí)中所建的資源與集群的其余資源相隔離。
kubectl create namespace default-mem-example
以下為 LimitRange 的示例清單。 清單中聲明了默認(rèn)的內(nèi)存請(qǐng)求和默認(rèn)的內(nèi)存限制。
apiVersion: v1
kind: LimitRange
metadata:
name: mem-limit-range
spec:
limits:
- default:
memory: 512Mi
defaultRequest:
memory: 256Mi
type: Container
在 default-mem-example 命名空間創(chuàng)建限制范圍:
kubectl apply -f https://k8s.io/examples/admin/resource/memory-defaults.yaml --namespace=default-mem-example
現(xiàn)在如果你在 default-mem-example 命名空間中創(chuàng)建一個(gè) Pod, 并且該 Pod 中所有容器都沒(méi)有聲明自己的內(nèi)存請(qǐng)求和內(nèi)存限制, 控制面 會(huì)將內(nèi)存的默認(rèn)請(qǐng)求值 256MiB 和默認(rèn)限制值 512MiB 應(yīng)用到 Pod 上。
以下為只包含一個(gè)容器的 Pod 的清單。該容器沒(méi)有聲明內(nèi)存請(qǐng)求和限制。
apiVersion: v1
kind: Pod
metadata:
name: default-mem-demo
spec:
containers:
- name: default-mem-demo-ctr
image: nginx
創(chuàng)建 Pod
kubectl apply -f https://k8s.io/examples/admin/resource/memory-defaults-pod.yaml --namespace=default-mem-example
查看 Pod 的詳情:
kubectl get pod default-mem-demo --output=yaml --namespace=default-mem-example
輸出內(nèi)容顯示該 Pod 的容器有 256 MiB 的內(nèi)存請(qǐng)求和 512 MiB 的內(nèi)存限制。 這些都是 LimitRange 設(shè)置的默認(rèn)值。
containers:
- image: nginx
imagePullPolicy: Always
name: default-mem-demo-ctr
resources:
limits:
memory: 512Mi
requests:
memory: 256Mi
刪除你的 Pod:
kubectl delete pod default-mem-demo --namespace=default-mem-example
以下為只包含一個(gè)容器的 Pod 的清單。該容器聲明了內(nèi)存限制,而沒(méi)有聲明內(nèi)存請(qǐng)求。
apiVersion: v1
kind: Pod
metadata:
name: default-mem-demo-2
spec:
containers:
- name: default-mem-demo-2-ctr
image: nginx
resources:
limits:
memory: "1Gi"
創(chuàng)建 Pod:
kubectl apply -f https://k8s.io/examples/admin/resource/memory-defaults-pod-2.yaml --namespace=default-mem-example
查看 Pod 的詳情:
kubectl get pod default-mem-demo-2 --output=yaml --namespace=default-mem-example
輸出結(jié)果顯示容器的內(nèi)存請(qǐng)求被設(shè)置為它的內(nèi)存限制相同的值。注意該容器沒(méi)有被指定默認(rèn)的內(nèi)存請(qǐng)求值 256MiB。
resources:
limits:
memory: 1Gi
requests:
memory: 1Gi
以下為只包含一個(gè)容器的 Pod 的清單。該容器聲明了內(nèi)存請(qǐng)求,但沒(méi)有內(nèi)存限制:
apiVersion: v1
kind: Pod
metadata:
name: default-mem-demo-3
spec:
containers:
- name: default-mem-demo-3-ctr
image: nginx
resources:
requests:
memory: "128Mi"
創(chuàng)建 Pod:
kubectl apply -f https://k8s.io/examples/admin/resource/memory-defaults-pod-3.yaml --namespace=default-mem-example
查看 Pod 聲明:
kubectl get pod default-mem-demo-3 --output=yaml --namespace=default-mem-example
輸出結(jié)果顯示所創(chuàng)建的 Pod 中,容器的內(nèi)存請(qǐng)求為 Pod 清單中聲明的值。 然而同一容器的內(nèi)存限制被設(shè)置為 512MiB,此值是該命名空間的默認(rèn)內(nèi)存限制值。
resources:
limits:
memory: 512Mi
requests:
memory: 128Mi
如果你的命名空間設(shè)置了內(nèi)存 資源配額, 那么為內(nèi)存限制設(shè)置一個(gè)默認(rèn)值會(huì)很有幫助。 以下是內(nèi)存資源配額對(duì)命名空間的施加的三條限制:
當(dāng)你添加 LimitRange 時(shí):
如果該命名空間中的任何 Pod 的容器未指定內(nèi)存限制, 控制面將默認(rèn)內(nèi)存限制應(yīng)用于該容器, 這樣 Pod 可以在受到內(nèi)存 ResourceQuota 限制的命名空間中運(yùn)行。
刪除你的命名空間:
kubectl delete namespace default-mem-example
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: