網卡由于采用的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 |
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/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、監控解決方案...
閱讀 1353·2023-01-11 13:20
閱讀 1700·2023-01-11 13:20
閱讀 1211·2023-01-11 13:20
閱讀 1904·2023-01-11 13:20
閱讀 4162·2023-01-11 13:20
閱讀 2751·2023-01-11 13:20
閱讀 1397·2023-01-11 13:20
閱讀 3664·2023-01-11 13:20