企业级运维之云原生与Kubernetes实战课程 第三章第2讲 深入剖析linux容器&Pod(下)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 理解容器和pod的基本原理以及差异 理解pod创建的过程 理解各个控制器的作用 理解ack集群的网络原理以及coredns的原理

企业级运维之云原生与Kubernetes实战课程

第三章第2讲 深入剖析linux容器&Pod(下)

 

视频地址:https://developer.aliyun.com/learning/course/913/detail/14555

 

 

三、资源限制(cgroup

 

1.  控制器组(cgroup

 

cgroupLinux control group的缩写,cgroup是内核的一个特性,进程可以通过树形结构的cgroup来监控和限制进程可以使用的资源,比如限制某个进程对cpumemory的使用量等。

 

cgroup 驱动:

  • systemd cgroup driver
  • cgroupfs cgroup driver

 

cgroup 类型:

  • cpu
  • memory
  • pid
  • blkio
  • device
  • freezer

 

查看podcgroup信息:

a.  登录pod所在的节点, docker ps |grep <pod name>找到容器的容器id

b.  找到容器的Pid : docker inspect <容器id> |grep Pid

c.  查看容器cgroup相对路径: cat /proc/ <Pid>/cgroup |grep memory

 

示例:

# docker inspect 0683e462045a |grep -i pid

# cat /proc/905215/cgroup

image.png

 

# kubectl exec -it multi-containers-6695d87b75-dsxgn -- bash

 image.png

 

2.  cgroup子系统

 

pod中最主要的2cgroup子系统: cpumemory

 

a.  子系统cpu

 

cpu子系统:观察cpu是否受限以及如何临时取消限制。

 

  • cpuacct.stat
  • cpu.cfs_period_us
  • cpu.cfs_quota_us
  • cpuacct.usage
  • cpu.shares
  • cpu.stat
  • tasks

 

示例:

 image.png

 

# kubectl exec -it multi-containers-6695d87b75-dsxgn -c nginx -- bash

# cat /sys/fs/cgroup/cpu.stat

 image.png

 

# ssh root@192.168.88.156

# docker ps |grep mu

# docker inspect 0683e462045a |grep -i -pid

# grep -i cpu /proc/905215/cgroup

 image.png

 

# grep -i cpu /proc/905215/cgroup

 image.png

 

# cat cpu.cfs_quota_us

50000

# cat cpu.cfs_period_us

100000

 

Top命令查看,Cat cpu使用在50%,然后临时取消catcpu限制:

#echo -1 >cpu.cfs_quota_us

cat 瞬时cpu使用达到100%

 image.png

 

b.  子系统memory

 

Memory子系统:观察memory是否受限以及如何临时取消限制。

 image.png

 

  • memory.failcnt
  • memory.limit_in_bytes
  • memory.max_ usage_in_ bytes
  • memory.usage_in_bytes
  • memory.stat
  • memory.oom_control
  • tasks

 image.png

 

3.  超好用的commandsystem-cg*

 

  • Systemd-cgtop:观察systemd驱动管理的cgroup相关资源使用情况;
  • Systemd-cgls:列出systemd驱动管理的cgroup相关资源;

 

四、Init容器

 

Init容器是一种特殊容器,Pod内的应用容器启动之前运行。Init容器可以包括一些应用镜像中不存在的实用工具和安装脚本。

 

特点:

 

  • Init容器总是运行到完成;
  • Init容器不支持lifecyclelivenessProbereadinessProbestartupProbe,因为它们必须在Pod就绪之前运行完成;
  • 每一个Init容器都必须在下一个容器启动之前成功完成;
  • Pod内多个Init容器会按顺序依次执行;

 

示例:

 

  • 安装定制化的工具或者下载文件等;
  • 等待依赖准备完毕;
  • 初始化pod内核参数;

 image.png

 

五、pause容器

 

Pause容器在K8s中,被当作pod中所有容器的父容器,它为Pod提供一个沙箱(sandbox)环境。

 

作用:

  • pod中容器准备所需共享的命名空间;
  • 启用pid命名空间,开启init进程,回收容器中的进程;

 

代码片段:

 image.png

 

六、最佳实践

 

pod中容器缺少需要的sh命令,可以创建一个临时容器去调试pod中的容器。

 

步骤:

 

a.  查看pod名称;

b.  登录到pod所在节点;

c.  创建容器并绑定pod容器的命名空间;

d.  执行ps -efnetstat -ntp等命令;

 image.png

image.png

 

本讲小结

 

1.  容器中命名空间隔离以及控制器组限制资源的原理;

2.  容器中/容器外如何查看命名空间以及cgroup的配置文件;

3.  podInit容器与pause容器的基本概念和作用;

4.  如何创建一个临时容器来调试pod容器。

 

思考:

1.   pod多容器之间,共享哪些命名空间?

2.   如何修改pod的内核参数?

3.   有哪几种方法查看pod里的tcp/udp连接信息?

4.   如何查看pod是否有cpu/memory受限与否?

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
12天前
|
人工智能 运维 Kubernetes
阿里云容器服务AI助手2.0 - 新一代容器智能运维能力
2024年11月,阿里云容器服务团队进一步深度融合现有运维可观测体系,在场景上覆盖了K8s用户的全生命周期,正式推出升级版AI助手2.0,旨在更好地为用户使用和运维K8S保驾护航。
|
20天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
98 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
10天前
|
人工智能 运维 监控
容器服务Kubernetes场景下可观测体系生产级最佳实践
阿里云容器服务团队在2024年继续蝉联Gartner亚洲唯一全球领导者象限,其可观测体系是运维的核心能力之一。该体系涵盖重保运维、大规模集群稳定性、业务异常诊断等场景,特别是在AI和GPU场景下提供了全面的观测解决方案。通过Tracing、Metric和Log等技术,阿里云增强了对容器网络、存储及多集群架构的监控能力,帮助客户实现高效运维和成本优化。未来,结合AI助手,将进一步提升问题定位和解决效率,缩短MTTR,助力构建智能运维体系。
|
2月前
|
运维 Kubernetes Docker
深入理解容器化技术:Docker与Kubernetes的协同工作
深入理解容器化技术:Docker与Kubernetes的协同工作
74 12
|
2月前
|
Kubernetes Cloud Native 持续交付
容器化、Kubernetes与微服务架构的融合
容器化、Kubernetes与微服务架构的融合
51 1
|
2月前
|
Kubernetes Cloud Native API
深入理解Kubernetes——容器编排的王者之道
深入理解Kubernetes——容器编排的王者之道
59 1
|
2月前
|
Kubernetes Cloud Native 云计算
云原生入门:Kubernetes 和容器化基础
在这篇文章中,我们将一起揭开云原生技术的神秘面纱。通过简单易懂的语言,我们将探索如何利用Kubernetes和容器化技术简化应用的部署和管理。无论你是初学者还是有一定经验的开发者,本文都将为你提供一条清晰的道路,帮助你理解和运用这些强大的工具。让我们从基础开始,逐步深入了解,最终能够自信地使用这些技术来优化我们的工作流程。
|
1月前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
232 77
|
3天前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
41 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序

相关产品

  • 容器服务Kubernetes版