在CentOS系統上配置Kubernetes環境是一個相對復雜的過程,但以下步驟可以為你提供一個基本的指南。請注意,這些步驟可能會隨著Kubernetes版本的更新而發生變化,建議參考最新的官方文檔進行操作。
關閉防火墻:
sudo systemctl stop firewalld
sudo systemctl disable firewalld
關閉SELinux:
sudo setenforce 0
sudo sed -i 's/SELINUXenforcing/SELINUXdisabled/' /etc/selinux/config
配置靜態IP:
編輯 /etc/sysconfig/network-scripts/ifcfg-eth0
文件,設置以下內容:
DEVICE=eth0
BOOTPROTO=static
IPADDR=192.168.1.100
NETMASK=255.255.255.0
GATEWAY=192.168.1.1
DNS1=8.8.8.8
DNS2=8.8.4.4
ONBOOT=yes
保存并退出編輯器,然后重啟網絡服務以使配置生效:
sudo systemctl restart network
設置主機名和hosts文件:
sudo hostnamectl set-hostname k8s-master
echo "192.168.1.100 k8s-master" >> /etc/hosts
echo "192.168.1.101 k8s-node1" >> /etc/hosts
echo "192.168.1.102 k8s-node2" >> /etc/hosts
時間同步:
sudo yum install -y ntpdate
sudo ntpdate ntp.aliyun.com
安裝Docker倉庫:
sudo yum install -y yum-utils
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
安裝Docker:
sudo yum install -y docker-ce docker-ce-cli containerd.io
啟動Docker服務:
sudo systemctl start docker
sudo systemctl enable docker
配置Docker使用systemd作為cgroup driver:
編輯 /etc/docker/daemon.json
文件:
sudo tee /etc/docker/daemon.json << EOF
{
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": { "max-size": "100m" },
"storage-driver": "overlay2",
"storage-opts": ["overlay2.override_kernel_check=true"]
}
EOF
重啟Docker服務:
sudo systemctl restart docker
添加Kubernetes源:
cat << EOF > /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
安裝Kubernetes組件:
sudo yum install -y kubelet kubeadm kubectl
啟動并啟用kubelet服務:
sudo systemctl enable kubelet
sudo systemctl start kubelet
在Master節點上執行以下命令來初始化Kubernetes集群:
sudo kubeadm init --pod-network-cidr=10.244.0.0/16
初始化完成后,會輸出一些重要的信息,包括一個用于加入節點的命令。
將Kubectl配置到您的shell中:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
安裝網絡插件,如Flannel:
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
在Worker節點上,執行以下命令來加入集群:
sudo kubeadm join 192.168.1.100:6443 --token abcdef.0123456789abcdef --discovery-token-ca-cert-hash sha256:abcdef123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef
將 <Master-IP>
、<Master-Port>
、<Token>
和 <Hash>
替換為初始化Master節點時輸出的信息。
在Master節點上,使用以下命令來驗證集群狀態:
kubectl get nodes
您應該看到所有節點都處于Ready狀態。
以上步驟涵蓋了在CentOS上配置Kubernetes集群的基本流程。請根據實際需求和環境調整細節。