某环境客户部署了一个kubernetes集群,发现flannel的pod一直重启,始终处于CrashLoopBackOff状态。node
对于始终CrashLoopBackOff的pod,通常是应用自己的问题,须要查看具体pod的日志,经过kubectl logs -f --tail -n kube-system flannel-xxx
显示,“pod cidr not assigned”,而后flannel退出工具
检查日志显示的节点10.0.0.17的cidr,发现确实为空,而正常的环境倒是正常的。oop
--kube-subnet-mgr
,–kube-subnet-mgr表明其使用kube类型的subnet-manager。该类型有别于使用etcd的local-subnet-mgr类型,使用kube类型后,flannel上各Node的IP子网分配均基于K8S Node的spec.podCIDR属性—" contact the Kubernetes API for subnet assignment instead of etcd.
",而在第2步,咱们已经发现节点的podcidr为空。allocate-node-cidrs
为true,它和cluster-cidr
参数共同使用的时候,controller-manager
会为全部的Node资源分配容器IP段, 并将结果写入到PodCIDR
字段.检查环境kube-controller-manager的配置文件,发现问题所在。以下图,环境设置了cluster-cidr
为192.168.2.0/24
,同时设置了node-cidr-mask-size
为24
,node-cidr-mask-size
参数,用来表示kubernetes管理集群中节点的cidr掩码长度,默认是24位,须要从cluster-cidr
里面分配地址段,而设置的cluster-cidr
显然没法知足这个掩码要求,致使kube-controller-manager为节点分配地址失败。综上,能够修改node-cidr-mask-size
参数为24以上的数解决node无法分配podcidr问题,可是同时发现环境部署使用的kubernetes自动化工具分配集群的service-cluster-ip-range
也是从cluster-cidr
里面取一段,分配不知足居然使用了和cluster-cidr同样的地址,形成网段冲突。最终,让客户从新规划了网段,修改cluster-cidr
掩码从24位改成16位,后续flannel均启动正常。日志