這篇文章主要介紹“Kubernetes高可用集群如何升級到1.13.4版”,在日常操作中,相信很多人在Kubernetes高可用集群如何升級到1.13.4版問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Kubernetes高可用集群如何升級到1.13.4版”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
main upgrade, kubeadm/kubectl/kubelet upgrade
sudo apt install kubeadm=1.13.4-00 kubectl=1.13.4-00 kubelet=1.13.4-00
查看該版本的容器鏡像版本:
kubeadm config images list
輸出如下:
~# kubeadm config images list k8s.gcr.io/kube-apiserver:v1.13.4 k8s.gcr.io/kube-controller-manager:v1.13.4 k8s.gcr.io/kube-scheduler:v1.13.4 k8s.gcr.io/kube-proxy:v1.13.4 k8s.gcr.io/pause:3.1 k8s.gcr.io/etcd:3.2.24 k8s.gcr.io/coredns:1.2.6
原始的kubernetes鏡像文件在gcr上,不能直接下載。我給鏡像到了阿里云的杭州機房的容器倉庫里,拉取還是比較快的。
echo ""
echo "=========================================================="
echo "Pull Kubernetes v1.13.3 Images from aliyuncs.com ......"
echo "=========================================================="
echo ""
MY_REGISTRY=registry.cn-hangzhou.aliyuncs.com/openthings
## 拉取鏡像
docker pull ${MY_REGISTRY}/k8s-gcr-io-kube-apiserver:v1.13.4
docker pull ${MY_REGISTRY}/k8s-gcr-io-kube-controller-manager:v1.13.4
docker pull ${MY_REGISTRY}/k8s-gcr-io-kube-scheduler:v1.13.4
docker pull ${MY_REGISTRY}/k8s-gcr-io-kube-proxy:v1.13.4
docker pull ${MY_REGISTRY}/k8s-gcr-io-etcd:3.2.24
docker pull ${MY_REGISTRY}/k8s-gcr-io-pause:3.1
docker pull ${MY_REGISTRY}/k8s-gcr-io-coredns:1.2.6
## 添加Tag
docker tag ${MY_REGISTRY}/k8s-gcr-io-kube-apiserver:v1.13.4 k8s.gcr.io/kube-apiserver:v1.13.4
docker tag ${MY_REGISTRY}/k8s-gcr-io-kube-scheduler:v1.13.4 k8s.gcr.io/kube-scheduler:v1.13.4
docker tag ${MY_REGISTRY}/k8s-gcr-io-kube-controller-manager:v1.13.4 k8s.gcr.io/kube-controller-manager:v1.13.4
docker tag ${MY_REGISTRY}/k8s-gcr-io-kube-proxy:v1.13.4 k8s.gcr.io/kube-proxy:v1.13.4
docker tag ${MY_REGISTRY}/k8s-gcr-io-etcd:3.2.24 k8s.gcr.io/etcd:3.2.24
docker tag ${MY_REGISTRY}/k8s-gcr-io-pause:3.1 k8s.gcr.io/pause:3.1
docker tag ${MY_REGISTRY}/k8s-gcr-io-coredns:1.2.6 k8s.gcr.io/coredns:1.2.6
echo ""
echo "=========================================================="
echo "Pull Kubernetes v1.13.4 Images FINISHED."
echo "into registry.cn-hangzhou.aliyuncs.com/openthings, "
echo " by openthings@https://my.oschina.net/u/2306127."
echo "=========================================================="
echo ""保存為shell腳本,然后執行。
全新安裝:
#指定IP地址,1.13.4版本: sudo kubeadm init --kubernetes-version=v1.13.4 --apiserver-advertise-address=10.1.1.100 --pod-network-cidr=10.244.0.0/16 #注意,CoreDNS已經內置,不再需要參數--feature-gates CoreDNS=true
先查看一下需要升級的各個組件的版本。
使用kubeadm upgrade plan ,輸出的版本升級信息如下:
COMPONENT CURRENT AVAILABLE API Server v1.13.3 v1.13.4 Controller Manager v1.13.3 v1.13.4 Scheduler v1.13.3 v1.13.4 Kube Proxy v1.13.3 v1.13.4 CoreDNS 1.2.6 1.2.6 Etcd 3.2.24 3.2.24
確保上面的容器鏡像已經下載(如果沒有提前下載,可能被網絡阻隔導致掛起),然后執行升級:
kubeadm upgrade -y apply v1.13.4
看到下面信息,就OK了。
[upgrade/successful] SUCCESS! Your cluster was upgraded to "v1.13.4". Enjoy!
然后,配置當前用戶環境:
mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config
就可以使用 kubectl version 來查看狀態和 kubectl cluster-info 查看服務地址。
注意:
所有節點預先拉取最新版本的鏡像,參考上面的方法。
主節點升級命令 kubeadm upgrade 可以從任意高可用主控制器啟動。
升級過程中會報etcd錯誤,因為在設置高可用時進行了修改,不用理會。目前kubeadm的upgrade不會改變其設置。
每個工作節點需要拉取上面對應版本的鏡像,以及安裝kubelet的對應版本。
檢查版本:
~$ kubectl version
對于高可用集群,需要對除升級完的 master 節點外的各個節點修改鏡像的版本。
分別打開/etc/kubernetes/manifest下面的文件,將其中的images版本修改為1.13.4。
kube-apiserver.yaml
kube-controller-manager.yaml
kube-scheduler.yaml
保存后,kubelet服務將會自動重啟相應的容器實例。
查看 node 狀態。
kubectl get node -o wide
顯示狀態如下:
NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP OS-IMAGE KERNEL-VERSION CONTAINER-RUNTIME podc01 Ready master 75d v1.13.3 10.1.1.201 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.3 podc02 Ready <none> 69d v1.13.3 10.1.1.202 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.2 podc03 Ready <none> 75d v1.13.3 10.1.1.203 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.2 podc04 Ready <none> 75d v1.13.3 10.1.1.204 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.3 pods01 Ready <none> 73d v1.13.3 10.1.1.193 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.2 pods02 Ready <none> 70d v1.13.3 10.1.1.234 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.2 pods03 Ready <none> 70d v1.13.3 10.1.1.205 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.3 pods04 Ready <none> 70d v1.13.3 10.1.1.112 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.2 pods05 Ready <none> 13d v1.13.3 10.1.1.150 <none> Ubuntu 18.04.2 LTS 4.15.0-45-generic docker://18.9.2
到此,關于“Kubernetes高可用集群如何升級到1.13.4版”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。