2024年最全【Kubernetes 系列】K8S 进阶 容器和 Pod 分配内存资源(2),h5的面试题

最后

总而言之,Android开发行业变化太快,作为技术人员就要保持终生学习的态度,让学习力成为核心竞争力,所谓“活到老学到老”只有不断的学习,不断的提升自己,才能跟紧行业的步伐,才能不被时代所淘汰。

在这里我分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司20年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  1. 使用命令启动 metrics-server:

$ minikube addons enable metrics-server

🌟 启动 ‘metrics-server’ 插件

  1. 查看 metrics-server 或资源 API (metrics.k8s.io) 是否已经运行,运行以下命令:

$ kubectl get apiservices

  1. 如果资源 API 可用,则输出结果将包含对 metrics.k8s.io 的引用信息。

NAME

v1beta1.metrics.k8s.io



二、创建命名空间

======================================================================

创建一个命名空间,以便将练习中创建的资源与集群的其余部分隔离。

$ kubectl create namespace mem-example

三、指定内存请求和限制

=========================================================================

要为容器指定内存请求,在容器资源清单中包含 resources:requests 字段。 同理,要指定内存限制,需要包含 resources:limits

我们先创建一个拥有一个容器的 Pod。 容器将会请求 100 MiB 内存,并且内存会被限制在 200 MiB 以内。

pods/resource/memory-request-limit.yaml 目标中 Pod 的配置文件如下:


apiVersion: v1

kind: Pod

metadata:

  name: memory-demo

  namespace: mem-example

spec:

  containers:

  - name: memory-demo-ctr

    image: polinux/stress

    resources:

      requests:

        memory: "100Mi"

      limits:

        memory: "200Mi"

    command: ["stress"]

    args: ["--vm", "1", "--vm-bytes", "150M", "--vm-hang", "1"]



配置文件的 args 部分提供了容器启动时的参数。 "--vm-bytes", "150M" 参数告知容器尝试分配 150 MiB 内存。

  1. 创建pod:

$ kubectl apply -f https://k8s.io/examples/pods/resource/memory-request-limit.yaml --namespace=mem-example

  1. 验证 Pod 中的容器是否已运行:

$ kubectl get pod memory-demo --namespace=mem-example

  1. 查看 Pod 相关的详细信息:

$ kubectl get pod memory-demo --output=yaml --namespace=mem-example

  1. 输出结果显示:该 Pod 中容器的内存请求为 100 MiB,内存限制为 200 MiB。这里我只截取一部分信息:

resources:

  requests:

    memory: 100Mi

  limits:

    memory: 200Mi



  1. 运行 kubectl top 命令,获取 Pod 的指标数据:

$ kubectl top pod memory-demo --namespace=mem-example

输出结果显示:Pod 正在使用的内存大约为 162,900,000 字节,约为 150 MiB。 这大于 Pod 请求的 100 MiB,但在 Pod 限制的 200 MiB之内。

NAME CPU(cores) MEMORY(bytes)

memory-demo 162856960

  1. 删除 Pod:

$ kubectl delete pod memory-demo --namespace=mem-example

四、超过容器限制的内存

=========================================================================

当节点拥有足够的可用内存时,容器可以使用其请求的内存。 但是,容器不允许使用超过其限制的内存。 如果容器分配的内存超过其限制,该容器会成为被终止的候选容器。 如果容器继续消耗超出其限制的内存,则终止容器。 如果终止的容器可以被重启,则 kubelet 会重新启动它,就像其他任何类型的运行时失败一样。

我们先在目录 pods/resource/memory-request-limit-2.yaml 创建一个 Pod,尝试分配超出其限制的内存。 这是一个 Pod 的配置文件,其拥有一个容器,该容器的内存请求为 50 MiB,内存限制为 100 MiB:


apiVersion: v1

kind: Pod

metadata:

  name: memory-demo-2

  namespace: mem-example

spec:

  containers:

  - name: memory-demo-2-ctr

    image: polinux/stress

    resources:

      requests:

        memory: "50Mi"

      limits:

        memory: "100Mi"

    command: ["stress"]

    args: ["--vm", "1", "--vm-bytes", "250M", "--vm-hang", "1"]



在配置文件的 args 部分中,你可以看到容器会尝试分配 250 MiB 内存,这远高于 100 MiB 的限制。

  1. 创建 pod:

$ kubectl apply -f https://k8s.io/examples/pods/resource/memory-request-limit-2.yaml --namespace=mem-example

  1. 查看 Pod 相关的详细信息:

$ kubectl get pod memory-demo-2 --namespace=mem-example

如果容器正在运行或被杀死。重复前面的命令,直到容器被杀掉:

NAME READY STATUS RESTARTS AGE

memory-demo-2 0/1 OOMKilled 1 24s

  1. 获取容器更详细的状态信息:

$ kubectl get pod memory-demo-2 --output=yaml --namespace=mem-example

输出结果显示:由于内存溢出(OOM),容器已被杀掉:


lastState:

   terminated:

     containerID: 65183c1877aaec2e8427bc95609cc52677a454b56fcb24340dbd22917c23b10f

     exitCode: 137

     finishedAt: 2017-06-20T20:52:19Z

     reason: OOMKilled

     startedAt: null



容器可以被重启,所以 kubelet 会重启它。 多次运行下面的命令,可以看到容器在反复的被杀死和重启:

$ kubectl get pod memory-demo-2 --namespace=mem-example

输出结果显示:容器被杀掉、重启、再杀掉、再重启……:

kubectl get pod memory-demo-2 --namespace=mem-example

NAME READY STATUS RESTARTS AGE

memory-demo-2 0/1 OOMKilled 1 37s

kubectl get pod memory-demo-2 --namespace=mem-example

NAME READY STATUS RESTARTS AGE

memory-demo-2 1/1 Running 2 40s

  1. 查看该 Pod 历史的详细信息:

$ kubectl describe pod memory-demo-2 --namespace=mem-example

输出结果显示:该容器反复的在启动和失败:

… Normal Created Created container with id 66a3a20aa7980e61be4922780bf9d24d1a1d8b7395c09861225b0eba1b1f8511

… Warning BackOff Back-off restarting failed container

  1. 查看集群节点的详细信息:

$ kubectl describe nodes

输出结果包含了一条练习中的容器由于内存溢出而被杀掉的记录:

Warning OOMKilling Memory cgroup out of memory: Kill process 4481 (stress) score 1994 or sacrifice child

  1. 删除 Pod:

$ kubectl delete pod memory-demo-2 --namespace=mem-example

五、超过节点容量的内存

=========================================================================

内存请求和限制是与容器关联的,但将 Pod 视为具有内存请求和限制,也是很有用的。 Pod 的内存请求是 Pod 中所有容器的内存请求之和。 同理,Pod 的内存限制是 Pod 中所有容器的内存限制之和。

Pod 的调度基于请求。只有当节点拥有足够满足 Pod 内存请求的内存时,才会将 Pod 调度至节点上运行。

我们在 pods/resource/memory-request-limit-3.yaml 目录下再创建一个 Pod,其内存请求超过了你集群中的任意一个节点所拥有的内存。 这是该 Pod 的配置文件,其拥有一个请求 1000 GiB 内存的容器,这应该超过了你集群中任何节点的容量。



### 总结

最后为了帮助大家深刻理解Android相关知识点的原理以及面试相关知识,这里放上相关的我搜集整理的24套**腾讯、字节跳动、阿里、百度2019-2021面试真题解析**,我把技术点整理成了**视频和PDF**(实际上比预期多花了不少精力),包**知识脉络 + 诸多细节**。

还有 **高级架构技术进阶脑图、Android开发面试专题资料** 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

![一线互联网面试专题](https://img-blog.csdnimg.cn/img_convert/1fb76ba08cb51ca755ab2f3c05e5d16d.webp?x-oss-process=image/format,png)

![379页的Android进阶知识大全](https://img-blog.csdnimg.cn/img_convert/6482d078fecf95030754fb25eb7980c5.webp?x-oss-process=image/format,png)

![379页的Android进阶知识大全](https://img-blog.csdnimg.cn/img_convert/4fa939256e95d7c5166dbe68ac851781.webp?x-oss-process=image/format,png)

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

> 2021年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。祝大家2021年万事大吉。



**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618156601)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

> 2021年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。祝大家2021年万事大吉。



**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618156601)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 7
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值