Kubernetes故障篇:calico/node is not ready: BIRD is not ready

1 篇文章 0 订阅

一、问题现象

1. k8s集群部署后发现calico的pod未通过健康检查,如下所示:

 kubectl get pods -A -o wide

image

可以看到 k8s-mater节点未Ready,会导致主节点访问node显示拒接连接。即: curl 10.0.169.144 显示为拒绝连接

image

2. 通过命令kubectl describe pods calico-node-8lb6j -n kube-system,查看其中一个pod信息,如下所示:

kubectl describe pods calico-node-8lb6j -n kube-system

image

二、解决方法

解决方案:调整calicao网络插件的网卡发现机制,修改IP_AUTODETECTION_METHOD对应的value值。官方提供的yaml文件中,ip识别策略(IPDETECTMETHOD)没有配置,即默认为first-found,这会导致一个网络异常的ip作为nodeIP被注册,从而影响node-to-node mesh。我们可以修改成can-reach或者interface的策略,尝试连接某一个Ready的node的IP,以此选择出正确的IP。

操作如下:

2.1 查看本机网卡信息

image

2.2 修改 calico配置

# 修改calico,添加配置项
kubectl edit daemonset calico-node -n calico-system -o yaml
# Cluster type to identify the deployment type
- name: IP_AUTODETECTION_METHOD #增加内容
  value: "interface=ens*" 或者 value: "interface=eth0|bond6|em1"     #增加内容
# 下面内容是里默认的不修改  
- name: CLUSTER_TYPE
  value: "k8s,bgp"
# Auto-detect the BGP IP address.
- name: IP
  value: "autodetect"
# Enable IPIP
- name: CALICO_IPV4POOL_IPIP
  value: "Always"

2.3 查看结果

kubectl get pods -n kube-system

image

curl 10.0.169.144

image

参考:https://www.cnblogs.com/codertl/p/17021964.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值