Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

时间:2023-01-04 16:09:09

文章来源:【DevOps和k8s全栈技术】

问题1:Kubernetes集群服务访问失败?

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

原因分析:证书不能被识别,其原因为:自定义证书,过期等。
解决方法:更新证书即可。

问题2:Kubernetes集群服务访问失败?

curl: (7) Failed connect to 10.103.22.158:3000; Connection refused

原因分析:端口映射错误,服务正常工作,但不能提供服务。
解决方法:删除SVC,重新映射端口即可。

kubectl delete svc nginx-deployment

 

问题3:Kubernetes集群服务暴露失败?

Error from server (AlreadyExists): services "nginx-deployment" already exists

原因分析:该容器已暴露服务了。
解决方法:删除SVC,重新映射端口即可。

问题4:外网无法访问Kubernetes集群提供的服务?

原因分析:‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍‍Kubernetes集群的type为ClusterIP,未将服务暴露至外网。
解决方法:修改Kubernetes集群的type为NodePort即可,于是可通过所有Kubernetes集群节点访问服务。

kubectl edit svc nginx-deployment

 

问题4:Pod状态为ErrImagePull?

readiness-httpget-pod   0/1     ErrImagePull   0          10s

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

原因分析:image无法拉取。

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

解决方法:更换镜像即可。
问题5:创建init C容器后,其状态不正常?

NAME READY STATUS RESTARTS AGE
myapp-pod 0/1 Init:0/2 0 20s

原因分析:查看日志发现,Pod一直出于初始化中;然后查看Pod详细信息,定位Pod创建失败的原因为:初始化容器未执行完毕。

Error from server (BadRequest): container "myapp-container" in pod "myapp-pod" is waiting to start: PodInitializing

解决方法:更换镜像即可。

问题6:创建init C容器后,其状态不正常?

NAME READY STATUS RESTARTS AGE
myapp-pod 0/1 Init:0/2 0 20s

原因分析:查看日志发现,Pod一直出于初始化中;然后查看Pod详细信息,定位Pod创建失败的原因为:初始化容器未执行完毕。

Error from server (BadRequest): container "myapp-container" in pod "myapp-pod" is waiting to start: PodInitializing

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

waiting for myservice

Server: 10.96.0.10
Address: 10.96.0.10:53

** server can't find myservice.default.svc.cluster.local: NXDOMAIN

*** Can't find myservice.svc.cluster.local: No answer
*** Can't find myservice.cluster.local: No answer
*** Can't find myservice.default.svc.cluster.local: No answer
*** Can't find myservice.svc.cluster.local: No answer
*** Can't find myservice.cluster.local: No answer

解决方法:创建相关Service,将SVC的name写入Kubernetes集群的CoreDNS服务器中,于是CoreDNS就能对Pod的init C容器执行过程中的域名解析了。

kubectl apply -f myservice.yaml

问题7:探测存活Pod状态为CrashLoopBackOff?
原因分析:镜像问题,导致容器重启失败。
解决方法:更换镜像即可。

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

问题8:Pod创建失败?

readiness-httpget-pod 0/1 Pending 0 0s
readiness-httpget-pod 0/1 Pending 0 0s
readiness-httpget-pod 0/1 ContainerCreating 0 0s
readiness-httpget-pod 0/1 Error 0 2s
readiness-httpget-pod 0/1 Error 1 3s
readiness-httpget-pod 0/1 CrashLoopBackOff 1 4s
readiness-httpget-pod 0/1 Error 2 15s
readiness-httpget-pod 0/1 CrashLoopBackOff 2 26s
readiness-httpget-pod 0/1 Error 3 37s
readiness-httpget-pod 0/1 CrashLoopBackOff 3 52s
readiness-httpget-pod 0/1 Error 4 82s

原因分析:镜像问题导致容器无法启动。

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

解决方法:更换镜像。

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

问题9:Pod的ready状态未进入?

readiness-httpget-pod   0/1     Running   0          116s

原因分析:Pod的执行命令失败,无法获取资源。

解决方法:进入容器内部,创建yaml定义的资源。

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

问题10:Pod创建失败?

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习

原因分析:yml文件内容出错—-使用中文字符。
解决方法:修改myregistrykey内容即可。

Kubernetes常见的日常故障处理指南|干货分享|适合各类基础人员学习