0

0

Linux容器编排项目教程_KubernetesPod管理与调度实践

冷炫風刃

冷炫風刃

发布时间:2026-01-07 18:29:14

|

998人浏览过

|

来源于php中文网

原创

Pod是Kubernetes最小可调度单元,由一个或多个共享网络、存储和生命周期的容器组成;其状态包括Pending、Running、Succeeded、Failed、Unknown;常用操作有kubectl run、exec、logs、delete;调度受nodeSelector、affinity、taints/tolerations、resources影响;排查启动失败需先kubectl describe查看Events,再检查镜像、资源、配置及日志。

linux容器编排项目教程_kubernetespod管理与调度实践

Kubernetes 中 Pod 是最小的可调度单元,管理好 Pod 是集群稳定运行的基础。 它不是独立运行的进程,而是由一个或多个紧密关联的容器组成的逻辑主机,共享网络、存储和生命周期。理解 Pod 的创建、状态、调度机制和常见问题处理方式,是日常运维和应用部署的核心能力。

Pod 的生命周期与状态解析

Pod 从创建到终止会经历多个阶段,Kubelet 持续监控并上报其状态。常用状态包括:

  • Pending:已提交但尚未被调度(如资源不足、镜像拉取中、节点未就绪)
  • Running:已绑定到节点,且至少一个容器正在运行(含初始化容器完成)
  • Succeeded:所有容器成功退出且不会重启(多见于 Job)
  • Failed:至少一个容器以非零码退出,且不满足重启策略
  • Unknown:节点失联或状态无法获取(需检查 kubelet 或网络)

通过 kubectl get pods 查看简略状态,用 kubectl describe pod 查看事件(Events)和容器详细状态,这是定位启动失败最直接的方式。

手动管理 Pod 的常用操作

虽然生产环境推荐使用控制器(如 Deployment)管理 Pod,但调试和临时任务仍需直接操作:

Linux+PHP+MySQL案例教程
Linux+PHP+MySQL案例教程

本书以培养高级网站建设与管理人才为目标,内容循序渐进,由浅入深,通过大量的实例系统全面地介绍了Linux+PHP+MySQL环境下的网络后台开发技术。本书详尽分析了近30个典型案例。包括计数器、网站流量统计、留言板、论坛系统、聊天室、投票与调查、用户管理、新闻发布系统、广告轮播、购物系统等等,力求让读者通过对案例的学习,轻松掌握PHP和MySQL的编程精要,迅速掌握网络后台开发技巧。   本书适

下载
  • 创建临时 Pod:kubectl run debug-pod --image=busybox:1.35 -- sleep 3600
  • 进入容器执行命令:kubectl exec -it debug-pod -- sh(注意指定容器名若 Pod 含多个容器)
  • 查看日志:kubectl logs debug-pod;查看前 10 行:kubectl logs debug-pod --tail=10;跟踪实时日志:kubectl logs -f debug-pod
  • 删除 Pod:kubectl delete pod debug-pod(控制器会自动重建,除非是裸 Pod)

影响 Pod 调度的关键配置

Kubernetes 默认使用默认调度器将 Pod 分配到合适节点,但可通过以下方式干预调度行为:

  • 节点选择器(nodeSelector):要求 Pod 只能运行在带指定 label 的节点上,例如 disktype: ssd
  • 亲和性与反亲和性(affinity):比 nodeSelector 更灵活,支持软硬约束,比如“尽量和某类服务部署在同一可用区”或“避免和数据库 Pod 同节点”
  • Taints 和 Tolerations:给节点打“污点”,只有带对应“容忍”的 Pod 才能调度上去,常用于专用节点(如 GPU 节点、系统组件节点)
  • 资源请求(requests)与限制(limits):决定 Pod 是否能被调度(requests 影响调度决策)、是否会被 OOMKilled(limits 影响 cgroup 限制)

排查 Pod 启动失败的典型路径

当 Pod 卡在 Pending 或 CrashLoopBackOff,按顺序检查:

  • 运行 kubectl describe pod ,重点看 Events 区域(如 “FailedScheduling”、“ImagePullBackOff”、“Failed to pull image”)
  • 确认镜像名称是否正确、仓库是否可达、是否需要 secret 拉取私有镜像
  • 检查节点资源是否充足(kubectl describe nodes 查看 Allocatable 和 Used)
  • 验证容器启动命令和参数是否合法(如 CMD 不存在、挂载路径错误、权限不足)
  • 若为 CrashLoopBackOff,先查日志:kubectl logs --previous(上一次崩溃的日志)

相关专题

更多
数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

269

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2023.12.29

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

340

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2072

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

346

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

253

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

322

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

405

2023.10.16

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.8万人学习

Git 教程
Git 教程

共21课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号