手動搭建 K8S 環境搭建
首先前期我們準備好三臺 Centos7 機器,配置如下:
主機名 | IP | 系統版本 |
---|---|---|
k8s-master | 192.168.41.141 | Centos7 |
k8s-node1 | 192.168.41.142 | Centos7 |
k8s-node2 | 192.168.41.143 | Centos7 |
前期準備
首先在三臺機器上都執行如下的命令
# 關閉防火墻
systemctl stop firewalld
systemctl disable firewalld
# 永久關閉 selinux
sed -i 's/enforcing/disabled/' /etc/selinux/config
# 永久關閉 swap
sed -ri 's/.*swap.*/#&/' /etc/fstab
# 修改/etc/hosts
vim /etc/hosts
192.168.41.141 k8s-master
192.168.41.142 k8s-node1
192.168.41.143 k8s-node2
# 將橋接的IPv4流量傳遞到iptables的鏈
cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
# 生效
sysctl --system
# 時間同步
yum install ntpdate -y
ntpdate time.windows.com
然后在三臺機器上都配置阿里云的 K8s 源,執行如下的命令
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
然后在三臺機器上均安裝 docker、kubeadm、kubelet、kubectl
安裝 docker,在三臺機器上均執行如下的命令一鍵安裝
curl -s https://get.docker.com/ | sh
如下所示安裝完成:
配置docker鏡像下載加速器,執行如下的命令:
vim /etc/docker/daemon.json{"registry-mirrors": ["https://b9pmyelo.mirror.aliyuncs.com"],"exec-opts": ["native.cgroupdriver=systemd"]
}#查看docker信息,進行確認
systemctl restart docker
docker info
出現如下信息則顯示配置完成
接著執行如下命令安裝 kubelet、kubeadm 和 kubectl
#安裝 kubelet、kubeadm 和 kubectl
yum install -y kubelet-1.21.0 kubeadm-1.21.0 kubectl-1.21.0
#設置 kubelet 開機自啟
systemctl enable kubelet
部署 K8S-master
在 master 節點執行如下命令初始化 master
kubeadm init --apiserver-advertise-address=192.168.41.141 --image-repository registry.aliyuncs.com/google_containers --kubernetes-version v1.21.0 --service-cidr=10.96.0.0/12 --pod-network-cidr=10.244.0.0/16 --ignore-preflight-errors=all--apiserver-advertise-address 集群通告地址
--image-repository 由于默認拉取鏡像地址k8s.gcr.io國內無法訪問,這里指定阿里云鏡像倉庫地址
--kubernetes-version K8s版本,與上面安裝的一致
--service-cidr 集群內部虛擬網絡,Pod統一訪問入口
--pod-network-cidr Pod網絡,與下面部署的CNI網絡組件yaml中保持一致
或者使用配置文件引導:
vi kubeadm.conf
apiVersion: kubeadm.k8s.io/v1beta2
kind: ClusterConfiguration
kubernetesVersion: v1.21.0
imageRepository: registry.aliyuncs.com/google_containers
networking:podSubnet: 10.244.0.0/16 serviceSubnet: 10.96.0.0/12
然后執行以下的命令初始化
kubeadm init --config kubeadm.conf --ignore-preflight-errors=all
初始化完成后,最后會輸出一個 join命令,先記住,下面用
然后拷貝kubectl使用的連接k8s認證文件到默認路徑:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
部署 K8S-node
在兩個 node 節點(192.168.41.142/143)執行如下命令即可加入 K8S 集群
kubeadm join 192.168.41.141:6443 --token sec4pk.nnihf0tismgn6kax --discovery-token-ca-cert-hash sha256:a8a0adf8b5fd9adb6ac8a2977456bd1671055146ed5711eaab5280d6541986fd
默認token有效期為24小時,當過期之后,該token就不可用了。這時就需要重新創建token,可以直接使用命令快捷生成:
kubeadm token create --print-join-command
部署容器網絡(CNI)
部署網絡 Calico 是一個純三層的數據中心網絡方案,是目前 Kubernetes 主流的網絡方案,執行以下的命令下載YAML:
wget https://docs.projectcalico.org/v3.19/manifests/calico.yaml --no-check-certificate
下載完后還需要修改里面定義 Pod 網絡(CALICO_IPV4POOL_CIDR),與之前
kubeadm init 的 --pod-network-cidr 指定的一樣
vim calico.yaml
默認 calico.yaml 中所使用的鏡像都來源于 docker.io 國外鏡像源,這里我們可以刪除 docker.io 前綴以使鏡像從國內鏡像加速站點下載
cat calico.yaml |grep 'image:'
sed -i 's#docker.io/##g' calico.yaml
修改完后文件后,部署:
#部署
kubectl apply -f calico.yaml
#查看狀態,執行完上一條命令需要等一會才全部 running
kubectl get pods -n kube-system
等Calico Pod都Running,節點也會準備就緒
部署 Dashboard
Dashboard 是官方提供的一個 Web UI,可用于基本管理 K8s 資源,執行如下命令下載 yaml 文件。默認 Dashboard 只能集群內部訪問,修改 Service 為NodePort 類型,暴露到外部:
wget https://github.com/kubernetes/dashboard/releases/tag/v2.4.0/aio/deploy/recommended.yaml
修改如下,nodePort 的端口范圍為 30000-32767,這里設置為 31000,并且添加 type:NodePort
vim recommended.yaml
執行如下命令應用
kubectl apply -f recommended.yaml
在 master 節點創建 service account 并綁定默認 cluster-admin 管理員集群角色,執行如下的命令
# 創建用戶
kubectl create serviceaccount dashboard-admin -n kube-system
# 用戶授權
kubectl create clusterrolebinding dashboard-admin --clusterrole=cluster-admin -
-serviceaccount=kube-system:dashboard-admin
# 獲取用戶 Token
kubectl describe secrets -n kube-system $(kubectl -n kube-system get secret |
awk '/dashboard-admin/{print $1}')
然后我們獲得如下的token,然后使用輸出的 token 登錄 Dashboard 就好了
eyJhbGciOiJSUzI1NiIsImtpZCI6IjNpbzFJbTg4UjlpcjFBdS1rb1J3NzFtY3BETlhtVkQ3S0hXZWwwU0MwN1UifQ.eyJpc3MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9uYW1lc3BhY2UiOiJrdWJlLXN5c3RlbSIsImt1YmVybmV0ZXMuaW8vc2VydmljZWFjY291bnQvc2VjcmV0Lm5hbWUiOiJkYXNoYm9hcmQtYWRtaW4tdG9rZW4tYzdzcHAiLCJrdWJlcm5ldGVzLmlvL3NlcnZpY2VhY2NvdW50L3NlcnZpY2UtYWNjb3VudC5uYW1lIjoiZGFzaGJvYXJkLWFkbWluIiwia3ViZXJuZXRlcy5pby9zZXJ2aWNlYWNjb3VudC9zZXJ2aWNlLWFjY291bnQudWlkIjoiZjAyMTE1OWMtZjcyMC00YTZlLWFiY2MtYzIzYWRhZjBiZjk5Iiwic3ViIjoic3lzdGVtOnNlcnZpY2VhY2NvdW50Omt1YmUtc3lzdGVtOmRhc2hib2FyZC1hZG1pbiJ9.aD_ZtS0domXxtWz-2BaGmZebJMqoNvWqHgJ4K7kQ9eir5JvIqTsrxM14dNrUrEFRZC2hw6Gn_xz7Nezy81XPU64HHcbGiNvNU8K7OwvTWwTOpDBRPho1CaxJsKBrlQwoNf1pzoShqO-JdL4kVfJUmKthjUqv8QduwVzEkCWeTXgcHOoPnsOaJSXJzwanAC4e5pIovcjMGQJU4W87T8uVW4bdO4w48c-101-mMYHMouKVRxF8OOTuGHFXUDpYCKAOvfA73gtwoyi_4wiSqS7NSZZTGwFfppUYDomjoA3FUFubZ2xLoc8fN2GoFzzTcylxFHTCfupJM2nUVs9vxQbJw
然后我們瀏覽器訪問 URL:https://master:31000或者 https://node:31000 均可
輸入獲得的token,就可以完成登陸了