记一次k8s pod的CrashLoopBackOff错误状态

背景经过:

k8s刚搭建完毕,组建图形界面dashboard时报错

主要原因:firewall仅开放了服务器ip,没有开放k8s pod之间的虚拟ip,网络不通
方法:放通或干脆关闭firewalld

检查pod状态

复制代码
kubectl get pod -n kubernetes-dashboard

注:

  1. 发现有pod不正常,先describe查看一下

查看pod描述

复制代码
kubectl describe pod kubernetes-dashboard-6b8f9cc89c-n7ff4 -n kubernetes-dashboard

注:

  1. 主要看最后面的Events,没发现具体异常,查看pod日志

查看pod日志

复制代码
kubectl logs -f kubernetes-dashboard-6b8f9cc89c-n7ff4 -n kubernetes-dashboard

注:

  1. 发现异常:dial tcp 10.96.0.1:443: connect: no route to host. 是pod内部网络问题导致无法连接

查看防火墙

复制代码
firewall-cmd --list-all

注:

  1. 服务器firewall只放通了192.169.10.0/16网段,pod内部虚拟网络通信是另外一组ip段(tcp 10.96.0.1:443: connect: no route to host)
  2. pod容器之间会创建虚拟网络互相通信。

解决办法:

复制代码
# k8s集群所有节点放通pod虚拟网卡网段
# 建议直接所有节点关闭firewall
systemctl disable firewalld --now

# 然后等待pod重启,或者手动删了重建
kubectl delete -f recommended.yaml
kubectl apply -f recommended.yaml

再次检查

复制代码
kubectl get pod -n kubernetes-dashboard

ps:获取已有pod的yaml

复制代码
kubectl get deploy -o yaml -n kubernetes-dashboard > recommended2.yaml

ps2:尽量用apply不用create

复制代码
create 是一次性创建命令,资源已存在时报错,仅适用于确认资源不存在的场景
apply 是声明式管理命令,支持创建/更新资源,重复执行无故障,是日常使用的首选
核心区别:create 只有创建能力,apply 兼具创建和增量更新能力。

ps3:使用edge浏览器打开自建https网站被拦截问题

复制代码
在浏览器被拦截页面,英文输入 thisisunsafe
相关推荐
m0_7381207211 分钟前
渗透测试基础——基于Docker的Rsync服务靶场搭建与原理讲解
运维·服务器·网络·安全·web安全·docker·容器
小义_1 小时前
【Ansible】(三)基础配置与连接设置
云原生·ansible
松岩1 小时前
网络问题导致 Pod Pending
kubernetes·aiops
极客先躯5 小时前
高级java每日一道面试题-2026年02月09日-实战篇[Docker]-Docker 容器有哪些安全风险?如何缓解?
java·运维·网络·安全·docker·容器
yuanzhengme5 小时前
Ollama【部署 07】搭建本地智能体的简单说明(局域网离线部署Ollama+模型迁移+Docker部署AnythingLLM)
运维·docker·容器·大模型·ollama·本地智能体
运维老郭6 小时前
Kubernetes 二进制部署完全指南:从零搭建生产级HA集群
运维·云原生·kubernetes
成为你的宁宁6 小时前
【K8S黑盒监控实践:Probe配置、Prometheus验证与Grafana可视化】
kubernetes·grafana·prometheus
成为你的宁宁6 小时前
【Prometheus Operator监控K8S Nginx】
nginx·kubernetes·prometheus
宇明一不急7 小时前
k8s headless svc
云原生·容器·kubernetes
容器魔方7 小时前
Karmada v1.18 版本发布!新增混合云溢出式调度能力
人工智能·云原生·容器·华为云·云计算