pod 网络访问不通简单整理

一:pod非running状态
先kubectl describe pod xxx
如果说pod是时好时坏,可以logs 查看
也可以kubectl exec -it xxx bash

什么情况下pod会处于pending状态?(pending状态pod是未分配,只有分配后才会拉取镜像)
情况:资源不足;污点;没有节点标签;没有匹配到标签。

集群部署类问题:
1 网络不通
检测方法telnet,ping
2 启动失败 (一般是配置文件或者依赖服务)
比如apiserver依赖etcd,etcd起不来,apiserver也起不来
3 平台不兼容
uname -a 查看,一般是x86_64,下载二进制包是amd64

网络类问题,一般指无法在集群内部或者外部无法访问应用。
service一般由kube-proxy组件实现。
在这里插入图片描述
检查步骤:
1 pod 是不是正常工作的?
有可能一会running,一会挂了,不断重启
2 service是否关联pod? service指定的target-port端口是否正确?
kubectl get ep
在这里插入图片描述
看对应的IP和端口和是不是pod 的IP和端口
get ep查看的是service对应pod的ip和端口,Kubernetes在创建Service时,根据Service的标签选择器(Label Selector)来查找Pod,据此创建与Service同名的EndPoints对象。

3 如果用名称访问,DNS是否正常工作?
kubectl get svc
pod—>coredns—>宿主机的dns
使用kubectl get pod -n kube-system
在这里插入图片描述
4 kube-proxy正常工作吗?因为名称访问service都是走的coredns ?是否正常写iptables规则? 检查coredns是不是正常的
比如kubectl get svc,然后使用 iptables-save | grep nginx (对应的svc的名称)
在这里插入图片描述
如果没有对应的iptables的规则,那么kube-proxy无法实现svc和pod之间的正常转发。
5 查看CNI网络是否正常
kubectl get pod -n kube-system 里面查看calico-xxx的pod是否有问题,restart数量是否为0
在这里插入图片描述

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kubernetes Pod 网络不通可能有多种原因。 首先,可能是 Pod 所属的 Node 网络故障。这可能是由于 Node 上的网络问题,例如网卡故障、网络配置错误或网络连接中断导致的。解决这个问题的方法可以是检查 Node 上的网络连接、查看网络配置或重启 Node。 其次,可能是 Pod 内部容器的网络配置问题。每个 Pod 可以包含多个容器,这些容器之间通过网络进行通信,但容器的网络配置可能存在问题。例如,容器的 IP 地址冲突、容器的网络策略限制、容器中的防火墙规则等等。解决这个问题的方法可以是检查容器的网络配置、查看容器日志或重新启动容器。 另外,还有可能是集群网络插件的问题。Kubernetes 支持多种网络插件(如Flannel、Calico等),这些插件负责连接 Pod 和 Node 之间的网络。如果网络插件配置有问题,可能会导致 Pod 网络不通。解决这个问题的方法可以是检查网络插件的配置、查看插件的日志或重新配置插件。 最后,还有可能是网络策略的限制导致 Pod 网络不通。Kubernetes 提供了网络策略功能,可以控制 Pod 之间的网络访问权限。如果网络策略配置有误或设置了不正确的规则,可能会导致 Pod 之间无法通信。解决这个问题的方法可以是检查网络策略的配置、查看策略的规则或调整策略的设置。 总之,Kubernetes Pod 网络不通可能有多种原因,需要根据具体情况进行排查,并寻找对应的解决方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值