网卡由于采用的DHCP动态获取IP,新创建的机器占用了K8Smaster节点的IP地址,K8S启动报错无法访问主节点,所以更换K8S的IP地址
报错如下:
把配置文件kube-apiserver.yaml中,替换以下几个地方的IP地址
cd /etc/Kubernetes mv admin.conf admin.conf_bak 使用如下命令生成新的admin.conf # kubeadm init phase kubeconfig admin --apiserver-advertise-address 192.168.37.128 I0920 09:50:30.940689 38240 version.go:252] remote version is much newer: v1.19.2; falling back to: stable-1.18 W0920 09:50:33.261484 38240 configset.go:202] WARNING: kubeadm cannot validate component configs for API groups [kubelet.config.k8s.io kubeproxy.config.k8s.io] [kubeconfig] Writing "admin.conf" kubeconfig file --192.168.37.128 为当前主机的IP地址 |
cd /etc/kubernetes/pki mv apiserver.key apiserver.key.bak mv apiserver.crt apiserver.crt.bak 使用如下命令生成 # kubeadm init phase certs apiserver --apiserver-advertise-address 192.168.37.128 I0920 09:55:31.656513 45703 version.go:252] remote version is much newer: v1.19.2; falling back to: stable-1.18 W0920 09:55:33.787879 45703 configset.go:202] WARNING: kubeadm cannot validate component configs for API groups [kubelet.config.k8s.io kubeproxy.config.k8s.io] [certs] Generating "apiserver" certificate and key [certs] apiserver serving cert is signed for DNS names [k8s1 kubernetes kubernetes.default kubernetes.default.svc kubernetes.default.svc.cluster.local] and IPs [10.96.0.1 192.168.37.128] --192.168.37.128 为当前主机的IP地址 |
root@k8s1 ~ # systemctl restart docker root@k8s1 ~ # systemctl restart kubelet |
cd /etc/kubernetes/ root@k8s1 /etc/kubernetes # kubectl get nodes --kubeconfig=admin.conf NAME STATUS ROLES AGE VERSION k8s1 Ready master 126d v1.18.2 k8s2 NotReady k8s3 NotReady k8s4 NotReady 可以看到master节点现在已经起来了 执行mv admin.conf ~/.kube/config,后续可以使用kubectl get nodes查看K8S集群状态了 root@k8s1 ~ # kubectl get nodes NAME STATUS ROLES AGE VERSION k8s1 Ready master 126d v1.18.2 k8s2 NotReady k8s3 NotReady k8s4 NotReady |
从2.7可以看到,master已经起来了,但是node节点都是notready的,到k8s2节点查看日志如下,其他node节点k83,k84也是如此
使用journalctl命令查看kubelet日志,可以看到K8S2还是连接的原来的IP192.168.37.129 journalctl -f -u kubelet Sep 20 10:14:58 k8s2 kubelet[102389]: E0920 10:14:58.673121 102389 file_linux.go:60] Unable to read config path "/etc/kubernetes/manifests": path does not exist, ignoring Sep 20 10:14:58 k8s2 kubelet[102389]: E0920 10:14:58.684202 102389 kubelet.go:2267] node "k8s2" not found Sep 20 10:14:58 k8s2 kubelet[102389]: E0920 10:14:58.784485 102389 kubelet.go:2267] node "k8s2" not found Sep 20 10:14:58 k8s2 kubelet[102389]: E0920 10:14:58.873297 102389 kubelet_node_status.go:92] Unable to register node "k8s2" with API server: Post https://192.168.37.129:6443/api/v1/nodes: dial tcp 192.168.37.129:6443: connect: connection refused Sep 20 10:14:58 k8s2 kubelet[102389]: E0920 10:14:58.884986 102389 kubelet.go:2267] node "k8s2" not found Sep 20 10:14:58 k8s2 kubelet[102389]: E0920 10:14:58.985714 102389 kubelet.go:2267] node "k8s2" not found Sep 20 10:14:59 k8s2 kubelet[102389]: E0920 10:14:59.021311 102389 controller.go:136] failed to ensure node lease exists, will retry in 3.2s, error: Get https://192.168.37.129:6443/apis/coordination.k8s.io/v1/namespaces/kube-node-lease/leases/k8s2?timeout=10s: dial tcp 192.168.37.129:6443: connect: connection refused Sep 20 10:14:59 k8s2 kubelet[102389]: E0920 10:14:59.073642 102389 reflector.go:178] k8s.io/kubernetes/pkg/kubelet/config/apiserver.go:46: Failed to list *v1.Pod: Get https://192.168.37.129:6443/api/v1/pods?fieldSelector=spec.nodeName%3Dk8s2&limit=500&resourceVersion=0: dial tcp 192.168.37.129:6443: connect: connection refused |
1.从master节点k8s1拷贝ca.crt到node节点对应的目录 scp ca.crt k8s2:/etc/kubernetes/pki/ 2.修改node节点的kubelet.conf,把server: https://192.168.37.129:6443修改为现在master节点的ip地址192.168.37.128 3.重启node节点的docker systemctl restart docker 4.使用kubectl get nodes查看,node状态已经正常 # kubectl get nodes NAME STATUS ROLES AGE VERSION k8s1 Ready master 126d v1.18.2 k8s2 Ready k8s3 Ready k8s4 Ready |
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/130092.html
摘要:使用安装安全高可用集群安装包地址如非高可用安装请忽略此教程,直接看产品页的三步安装。 使用kubeadm安装安全高可用kubernetes集群 安装包地址 如非高可用安装请忽略此教程,直接看产品页的三步安装。 单个master流程: 单master视频教程 解压后在master 上 cd shell && sh init.sh ,然后sh master.sh(注意因为脚本用的相...
摘要:使用安装安全高可用集群安装包地址如非高可用安装请忽略此教程,直接看产品页的三步安装。 使用kubeadm安装安全高可用kubernetes集群 安装包地址 如非高可用安装请忽略此教程,直接看产品页的三步安装。 单个master流程: 单master视频教程 解压后在master 上 cd shell && sh init.sh ,然后sh master.sh(注意因为脚本用的相...
摘要:使用安装安全高可用集群安装包地址如非高可用安装请忽略此教程,直接看产品页的三步安装。 使用kubeadm安装安全高可用kubernetes集群 安装包地址 如非高可用安装请忽略此教程,直接看产品页的三步安装。 单个master流程: 单master视频教程 解压后在master 上 cd shell && sh init.sh ,然后sh master.sh(注意因为脚本用的相...
kubeadm介绍kubeadm概述Kubeadm 是一个工具,它提供了 kubeadm init 以及 kubeadm join 这两个命令作为快速创建 kubernetes 集群的最佳实践。 kubeadm 通过执行必要的操作来启动和运行一个最小可用的集群。kubeadm 只关心启动集群,而不关心其他工作,如部署前的节点准备工作、安装各种Kubernetes Dashboard、监控解决方案...
阅读 1346·2023-01-11 13:20
阅读 1684·2023-01-11 13:20
阅读 1132·2023-01-11 13:20
阅读 1858·2023-01-11 13:20
阅读 4099·2023-01-11 13:20
阅读 2704·2023-01-11 13:20
阅读 1385·2023-01-11 13:20
阅读 3594·2023-01-11 13:20