Pod一直处于CrashLoopBackOff状态的排查思路

问题现象

一台宿主机上启动的Pod一直重启,describe报错信息如下

Pod sandbox changed, it will be killed and re-created.

信息在这里插入图片描述

原因分析

  1. Pod处于CrashLoopBackOff状态,第一想到的是Liveness probe failed或者OOM-kill; 测试Pod没有配置存活探测,查看对应机器也没有OOM-kill相关内核日志;
  2. 怀疑是否dockerd进程资源比较紧张,比如被死循环的容器一直消耗资源;查看机器资源都处于正常水平,排除Pod因为资源问题重启;
  3. 修改测试Pod的网络方式改为hostnetwork模式启动Pod,在问题机器上可以正常启动Pod,再次排除资源问题导致;
  4. SandboxChanged:怀疑是CNI 分配IP失败,导致循环分配,看起来比较像;于是查看网络插件canal Pod日志(hostnetwork模式)和kubelet日志查看具体过程;

以下是网络插件的日志信息,可以看到都是INFO日志,分配PodIP成功。

Pod一直处于CrashLoopBackOff状态的排查思路_第1张图片

以下是kubelet对应的日志,也可以看到使用了对应的Pod IP并分配给container

在这里插入图片描述

继续往下看kubelt的日志, 发现了一个可疑的error,使用nsenter 的某个参数失败,然后接下来是Endpoint will be hanled。 下一段日志又到了kubelet重新分配IP和container endpoint,这里和问题现象符合,docker ps可以看到有很多pause容器退出重建; 所以可以初步怀疑就是kubelet在创建Pod过程中卡在nsenter的使用方法上,对比nsenter的版本和help手册发现果然是该机器的nsenter问题。

Pod一直处于CrashLoopBackOff状态的排查思路_第2张图片

修复nsenter相关的bin文件后问题解决,也是第一次碰到,Pod创建过程中居然依赖nsenter工具,于是也去看了下对应的go代码,果然在分配IP后会使用nsenter检索IP,如果检索失败就会退出,对应的源码信息如下:

Pod一直处于CrashLoopBackOff状态的排查思路_第3张图片
Pod一直处于CrashLoopBackOff状态的排查思路_第4张图片

你可能感兴趣的:(K8S学习相关,docker,容器,运维,kubernetes)