PHP网络问题排查,K8S – 记一次网络问题排查

运维同学最近提供了一个K8S集群,但是使用的时候发现网络不通,于是展开了一次排查。

现象

node01(虚拟网段:10.244.0.0/24)部署了coredns,node02(虚拟网段:10.244.1.0/24)是我的容器,网络是flannel vxlan。

在我的容器中执行yum安装 工具 卡住,请求baidu.com也卡住。

第一阶段

在node02上通过ping baidu.com命令,确认没有解析到IP,所以是卡在DNS解析上。

K8S容器解析域名是调用coredns的service ip,尝试在ping coredns的POD IP发现不通。

在node02上执行iptables-save命令,发现的确有一条把forward包drop的规则:

021655d3094bd8d6ace3098f00397fe9.png

正常来说,物理网卡收到目标IP不是自己的包时,会把包forward给本机符合条件的内部网卡,从而进入容器中,所以一旦drop就肯定网络不通了。

删除所有机器上的drop规则后,测试发现仍旧无法联通coredns的POD IP。

第二阶段

在node02上,通过tcpdump -i flannel.1进行抓包观察,并在容器中ping coredns的POD IP,结果发现flannel.1上没有流量。

执行route -n查看了一下宿主机的路由表,发现了缺了一条到node01的路由规则,导致发往node01虚拟网段的流量没有经过flannel网关:

c6cb6a3888e2edeba69e214a06f1a7f6.png

node02的虚拟网段是10.244.1.0/24,所以本机POD之间直接走cni0网桥做2交换即可,而发往其他node的POD的流量都要发给flannel.1网关,由它在本机做vxlan封装后从eth0送出。

这里因为少了到node01网段10.244.0.0/24的路由规则,导致node02的包无法被flannel处理。

不太清楚运维做过什么操作导致flannel没有生成这条路由规则,重启了一下各个节点就恢复了:

31f0c6c8cad75fb4c4d91f009b6d13d4.png

此时发现,虽然到coredns的POD IP已经可以ping通,但是ping baidu.com仍旧卡在解析上得不到IP,这是什么鬼?

第三阶段

既然到coredns的4层网络已通,于是只能向应用层怀疑:要么是coredns服务端不好,要么是客户端不好。

排查服务端很简单,直接dig @coredns的IP baidu.con,发现可以解析到IP,所以coredns服务正常。

客户端只能看一下/etc/resolv.conf:

ea171c4cce59a54b268737bf8a25fa1f.png

这里nameserver配的是10.224.0.10,按道理这应该是coredns的service cluster ip。

但是直接查看K8S的service信息,发现coredns的service ip是10.192.0.10:

61282c3811134504ed231a87076826c7.png

也就说容器内配置的nameserver ip和coredns的service ip不一样,到底哪个是对的IP呢呢?显然下面的是对的,因为用这个IP可以访问到coredns,并且iptables规则里也是用的10.192.0.10做的service负载均衡:

98493d4a2867f714c15958a3ec11de93.png

与运维同学沟通,可能与初始化集群时候重复kubeadm init有关,导致前一次的DNS配置遗留到了最后一次配置中。

修复方法是在configmap中找到kubelet的配置:

3fe91379f300d2d91fc68cf645e691e3.png

里面有一个clusterDNS的配置,目前是错误的IP,改成当前coredns的service ip即可:

071ecc844bc6a3f124abf34204acdc19.png

需要重启集群,才能让所有POD应用新的nameserver配置。

最后

排查这个问题主要用到了几个东西:

route -n:查看路由表

ip addr:查看网卡、网桥

tcpdump:-i参数监听具体网卡

博主无私的分享着知识,你愿意送他一顿热腾腾的早餐吗?

9329ebdc2e7ea30c22a59982422cb3a6.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值