摘要:先移除集群的節(jié)點(diǎn)然后重置狀態(tài)我完全按照官方文檔安裝執(zhí)行,沒有遇到問題如果你在安裝過程中遇到問題,請(qǐng)參考下面官方的故障排除文檔和安裝文檔。
節(jié)點(diǎn)規(guī)劃
本次選用一個(gè)master節(jié)點(diǎn),三個(gè)node節(jié)點(diǎn)來安裝k8s集群?! ?/p>
節(jié)點(diǎn) | IP |
---|---|
M0 | 10.xx.xx.xx |
N0 | 10.xx.xx.xx |
N1 | 10.xx.xx.xx |
N2 | 10.xx.xx.xx |
包括修改主機(jī)名,關(guān)閉防火墻等操作?! ?br>k8s集群會(huì)識(shí)別主機(jī)名字,確保每個(gè)主機(jī)名設(shè)為不同值?! ?br>關(guān)閉防火墻是為了避免不必要的網(wǎng)絡(luò)問題?! ?/p>
# ${hostname}變量請(qǐng)?zhí)鎿Q成規(guī)劃的主機(jī)名,比如M0, N0, N1 sudo hostnamectl set-hostname ${hostname} systemctl stop firewalld systemctl disable firewalld setenforce 0 sed -i -re "/^s*SELINUX=/s/^/#/" -e "$iSELINUX=disabled" /etc/selinux/config
然后建立ssh的相互連接,方便后面?zhèn)魑募裁吹?。可以使?b>ssh-copy-id命令,也可以自己添加認(rèn)證。這個(gè)網(wǎng)上教程很多,自己搜一下
安裝docker(在每臺(tái)機(jī)器上執(zhí)行)yum install docker -y systemctl enable docker && systemctl start docker安裝kubeadm, kubelet, kubectl(每臺(tái)機(jī)器上執(zhí)行)
kubeadm: 快速創(chuàng)建k8s集群的工具
kubelet: k8s的基礎(chǔ)組件,負(fù)責(zé)對(duì)pod和container的創(chuàng)建和管理,與k8s集群master建立聯(lián)系
kubectl: k8s的客戶端工具,用來像集群發(fā)送命名
cat </etc/yum.repos.d/kubernetes.repo [kubernetes] name=Kubernetes baseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64 enabled=1 gpgcheck=1 repo_gpgcheck=1 gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg EOF yum install -y kubelet kubeadm kubectl
官網(wǎng)文檔上寫一些用戶在RHEL/Centos7系統(tǒng)上安裝時(shí),由于iptables被繞過導(dǎo)致路由錯(cuò)誤,需要在
sysctl的config文件中將net.bridge.bridge-nf-call-iptables設(shè)置為1.
cat </etc/sysctl.d/k8s.conf net.bridge.bridge-nf-call-ip6tables = 1 net.bridge.bridge-nf-call-iptables = 1 EOF sysctl --system
啟動(dòng)kubelet:
systemctl enable kubelet && systemctl start kubelet
至此,準(zhǔn)備工作就做好了。目前每隔幾秒kubelet就會(huì)重啟,直到收到kubeadm的命令?! ?br>所以用systemctl status kubelet看到kubelet沒有啟動(dòng)是正?,F(xiàn)象,可以多執(zhí)行幾次查看,就會(huì)發(fā)現(xiàn)kubelet處于不斷停止和重啟的狀態(tài).
kubeadm是k8s官方提供的工具,可以簡(jiǎn)單的創(chuàng)建一個(gè)安全可擴(kuò)展的k8s集群。
在執(zhí)行下面的操作之前,請(qǐng)確保前面的準(zhǔn)備工作已經(jīng)做完。特別是kubelet已經(jīng)安裝和啟動(dòng),kubeadm已經(jīng)安裝完成
啟動(dòng)master
在master節(jié)點(diǎn)執(zhí)行以下操作,并導(dǎo)出KUBECONFIG配置文件到環(huán)境變量:
記錄下kubeadm init的輸出信息,后面將會(huì)用到
# --pod-network-cidr=192.168.0.0/1參數(shù)是為了后面啟動(dòng)networ的Calico pod做準(zhǔn)備 kubeadm init --pod-network-cidr=192.168.0.0/16 export KUBECONFIG=/etc/kubernetes/admin.conf
安裝啟動(dòng)一個(gè)network的pod,這里選用Calico.
在啟動(dòng)任何pod之前,必須先啟動(dòng)一個(gè)network的pod, 用于pod之間的通信
kubectl apply -f https://docs.projectcalico.org/v2.6/getting- started/kubernetes/installation/hosted/kubeadm/1.6/calico.yaml
添加node節(jié)點(diǎn)到master(在每臺(tái)node上執(zhí)行以下命令)
當(dāng)執(zhí)行玩kubeadm init后會(huì)輸出以下信息,直接復(fù)制執(zhí)行就可以了
kubeadm join --token: --discovery-token-ca-cert- hash sha256:
至此為止k8s集群就建好了,可以在master節(jié)點(diǎn)輸出kubectl get nodes查看
在非master節(jié)點(diǎn)管理集群(可選)
如果不執(zhí)行這個(gè)操作,只能在master節(jié)點(diǎn)來管理集群。
把master節(jié)點(diǎn)的admin.conf配置文件復(fù)制到nodes節(jié)點(diǎn)當(dāng)中去,就能在node節(jié)點(diǎn)來管理集群了。
scp /etc/kubernetes/admin.conf [email protected]:/etc/kubernetes/ export KUBECONFIG=/etc/kubernetes/admin.conf
將API服務(wù)代理到localhost(可選)
這個(gè)很好理解,執(zhí)行 kubectl --kubeconfig proxy命令,也是要使用admin.conf的權(quán)限,直接復(fù)
制官方文檔:
if you want to connect to the API Server from outside the cluster you can use
kubectl proxy:
scp root@:/etc/kubernetes/admin.conf . kubectl --kubeconfig ./admin.conf proxy
You can now access the API Server locally at http://localhost:8001/api/v1
刪除集群在我們安裝k8s集群時(shí),可能會(huì)出現(xiàn)問題,需要重新安裝?! ?br>在我們重新執(zhí)行安裝步驟之前,必須要先銷毀我們建立好的k8s集群,在master節(jié)點(diǎn)下執(zhí)行以下命令?! ?/p>
# 先移除集群的node節(jié)點(diǎn) kubectl drain--delete-local-data --force --ignore-daemonsets kubectl delete node # 然后重置kubeadm狀態(tài) kubeadm reset
我完全按照官方文檔安裝執(zhí)行,沒有遇到問題. 如果你在安裝過程中遇到問題,請(qǐng)參考下面官方的故障排除文檔和安裝文檔。
故障排除:Troubleshooting Kubeadm
安裝文檔:Using kubeadm to create a cluster
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/8016.html
摘要:先移除集群的節(jié)點(diǎn)然后重置狀態(tài)我完全按照官方文檔安裝執(zhí)行,沒有遇到問題如果你在安裝過程中遇到問題,請(qǐng)參考下面官方的故障排除文檔和安裝文檔。 節(jié)點(diǎn)規(guī)劃 本次選用一個(gè)master節(jié)點(diǎn),三個(gè)node節(jié)點(diǎn)來安裝k8s集群?! ? 節(jié)點(diǎn) IP M0 10.xx.xx.xx N0 10.xx.xx.xx N1 10.xx.xx.xx N2 10.xx.xx.xx 集群?jiǎn)?..
摘要:集群安裝在節(jié)點(diǎn)上并準(zhǔn)備一個(gè)虛擬來做。節(jié)點(diǎn)集群?jiǎn)?dòng)前的準(zhǔn)備請(qǐng)用用戶執(zhí)行節(jié)點(diǎn)準(zhǔn)備工作在每臺(tái)機(jī)器上執(zhí)行包括修改主機(jī)名,關(guān)閉防火墻等操作。關(guān)閉防火墻是為了避免不必要的網(wǎng)絡(luò)問題。完了可以使用查看集群是否安裝完成。 前面我們安裝了一個(gè)簡(jiǎn)單的kubernetes集群,選用了1個(gè)master節(jié)點(diǎn)和三個(gè)node節(jié)點(diǎn)。etcd也沒有安裝成集群. 這次我們安裝一個(gè)3個(gè)master節(jié)點(diǎn)+etcd集群的kub...
摘要:集群安裝在節(jié)點(diǎn)上并準(zhǔn)備一個(gè)虛擬來做。節(jié)點(diǎn)集群?jiǎn)?dòng)前的準(zhǔn)備請(qǐng)用用戶執(zhí)行節(jié)點(diǎn)準(zhǔn)備工作在每臺(tái)機(jī)器上執(zhí)行包括修改主機(jī)名,關(guān)閉防火墻等操作。關(guān)閉防火墻是為了避免不必要的網(wǎng)絡(luò)問題。完了可以使用查看集群是否安裝完成。 前面我們安裝了一個(gè)簡(jiǎn)單的kubernetes集群,選用了1個(gè)master節(jié)點(diǎn)和三個(gè)node節(jié)點(diǎn)。etcd也沒有安裝成集群. 這次我們安裝一個(gè)3個(gè)master節(jié)點(diǎn)+etcd集群的kub...
摘要:使用安裝安全高可用集群安裝包地址如非高可用安裝請(qǐng)忽略此教程,直接看產(chǎn)品頁(yè)的三步安裝。 使用kubeadm安裝安全高可用kubernetes集群 安裝包地址 如非高可用安裝請(qǐng)忽略此教程,直接看產(chǎn)品頁(yè)的三步安裝。 單個(gè)master流程: 單master視頻教程 解壓后在master 上 cd shell && sh init.sh ,然后sh master.sh(注意因?yàn)槟_本用的相...
摘要:使用安裝安全高可用集群安裝包地址如非高可用安裝請(qǐng)忽略此教程,直接看產(chǎn)品頁(yè)的三步安裝。 使用kubeadm安裝安全高可用kubernetes集群 安裝包地址 如非高可用安裝請(qǐng)忽略此教程,直接看產(chǎn)品頁(yè)的三步安裝。 單個(gè)master流程: 單master視頻教程 解壓后在master 上 cd shell && sh init.sh ,然后sh master.sh(注意因?yàn)槟_本用的相...
閱讀 2479·2021-09-29 09:34
閱讀 3316·2021-09-23 11:21
閱讀 2508·2021-09-06 15:00
閱讀 1134·2019-08-30 15:44
閱讀 2036·2019-08-29 17:23
閱讀 3008·2019-08-29 16:44
閱讀 3064·2019-08-29 13:13
閱讀 1943·2019-08-28 18:12