容器资源限制

1、资源限制

容器资源限制:

  • resources.limits.cpu
  • resources.limits.memory
    容器使用的最小资源需求,作为容器调度时资源分配的依据:
    • resources.requests.cpu
    • resources.requests.memory
      CPU单位:可以写m也可以写浮点数,例:0.5=500m,1=1000m

资源限制案例:

apiVersion: v1
kind: Pod
metadata:
  labels:
    run: shenhua
    app: sh
  name: shenhua
  namespace: shopping
spec:
  containers:
  - image: nginx
    name: chuangshuo
    resources:
      limits:				#限制容器最多使用多少资源
        cpu: 1
        memory: 1Gi
      requests:			#容器使用的最小资源(对资源的规划,一般小于limits的20%-30%)
        cpu: 0.7
        memory: 700Mi
[root@k8s-master ~]# kubectl get pod -n shopping
NAME      READY   STATUS    RESTARTS   AGE
shenhua   1/1     Running   0          13m

[root@k8s-master ~]# kubectl describe pod -n shopping shenhua			#查看详细信息
Name:         shenhua
Namespace:    shopping
Priority:     0
Node:         k8s-node1/192.168.153.181
Start Time:   Wed, 11 May 2022 11:08:20 +0800
Labels:       app=sh
              run=shenhua
Annotations:  cni.projectcalico.org/containerID: 7b6fa167025cb2f0e56054cde552ad2a162ad5ea9897190a23882c64ae95ee7d
              cni.projectcalico.org/podIP: 10.244.36.120/32
              cni.projectcalico.org/podIPs: 10.244.36.120/32
Status:       Running
IP:           10.244.36.120
IPs:
  IP:  10.244.36.120
Containers:
  chuangshuo:
    Container ID:   docker://58d7aac4e6886aca5d3630918d1b2edaeb060a28ab115ad13ae9dd53ba74c19d
    Image:          nginx
    Image ID:       docker-pullable://nginx@sha256:0d17b565c37bcbd895e9d92315a05c1c3c9a29f762b011a10c54a66cd53c9b31
    Port:           <none>
    Host Port:      <none>
    State:          Running
      Started:      Wed, 11 May 2022 11:08:22 +0800
    Ready:          True
    Restart Count:  0
    Limits:
      cpu:     1
      memory:  1Gi
    Requests:
      cpu:        700m
      memory:     700Mi
    Environment:  <none>
    Mounts:
      /var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-m4hj5 (ro)
Conditions:
  Type              Status
  Initialized       True 
  Ready             True 
  ContainersReady   True 
  PodScheduled      True 
Volumes:
  kube-api-access-m4hj5:
    Type:                    Projected (a volume that contains injected data from multiple sources)
    TokenExpirationSeconds:  3607
    ConfigMapName:           kube-root-ca.crt
    ConfigMapOptional:       <nil>
    DownwardAPI:             true
QoS Class:                   Burstable
Node-Selectors:              <none>
Tolerations:                 node.kubernetes.io/not-ready:NoExecute op=Exists for 300s
                             node.kubernetes.io/unreachable:NoExecute op=Exists for 300s
Events:
  Type    Reason     Age        From               Message
  ----    ------     ----       ----               -------
  Normal  Scheduled  19m        default-scheduler  Successfully assigned shopping/shenhua to k8s-node1
  Normal  Pulling    <invalid>  kubelet            Pulling image "nginx"
  Normal  Pulled     <invalid>  kubelet            Successfully pulled image "nginx" in 818.678571ms
  Normal  Created    <invalid>  kubelet            Created container chuangshuo
  Normal  Started    <invalid>  kubelet            Started container chuangshuo
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Docker中,可以通过设置容器资源限制来控制容器资源使用情况。以下是一些常见的方法来调整Docker容器资源限制: 1. CPU限制:可以使用`--cpus`选项来设置容器可以使用的CPU核心数。例如,`docker run --cpus 2`将限制容器使用的CPU核心数为2个。 2. 内存限制:可以使用`--memory`选项来设置容器可以使用的内存限制。例如,`docker run --memory 1g`将限制容器可使用的内存为1GB。 3. 网络带宽限制:可以使用网络驱动程序的功能来限制容器的网络带宽。不同的网络驱动程序可能有不同的配置选项,可以根据具体的网络驱动程序文档进行设置。 4. IO限制:可以使用`--device-read-bps`和`--device-write-bps`选项来设置容器的设备IO读写速率的限制。例如,`docker run --device-read-bps /dev/sda:1mb --device-write-bps /dev/sda:1mb`将限制容器对设备的读写速率为1MB/s。 5. 进程数限制:可以使用`--pids-limit`选项来设置容器可以创建的进程数量的限制。例如,`docker run --pids-limit 100`将限制容器创建的进程数量为100个。 需要注意的是,不同的Docker版本和环境可能会有不同的限制方式和选项。建议查阅官方文档或相关资源来获取更详细的信息和适用于特定版本的调整方法。 通过调整这些资源限制,可以有效地控制容器资源使用情况,提高应用程序的性能和稳定性,并避免容器之间的资源争用问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值