环境准备
更新系统并安装依赖包
bash
sudo yum update -y
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
设置 Docker 镜像源(如果使用 Docker)
bash
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
sudo yum makecache fast
sudo yum install -y docker-ce docker-ce-cli containerd.io
systemctl start docker
systemctl enable docker
关闭防火墙和SELinux(生产环境中请根据实际情况调整安全策略)
bash
sudo systemctl stop firewalld
sudo systemctl disable firewalld
sudo setenforce 0
sudo sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config
添加 Kubernetes 的 YUM 源
bash
cat <<EOF | sudo tee /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-\$basearch
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
sudo yum makecache fast
安装 kubeadm、kubectl 和 kubelet
bash
sudo yum install -y kubelet-1.27.0 kubeadm-1.27.0 kubectl-1.27.0
sudo systemctl enable kubelet
配置kubelet开机启动时从kubeadm获取配置
bash
sudo systemctl daemon-reload
sudo systemctl restart kubelet
初始化 Master 节点
确保网络配置正确,并且主机名解析没有问题。然后初始化 master 节点:
bash
sudo kubeadm init --kubernetes-version=v1.27.0 \
--pod-network-cidr=10.244.0.0/16 \
[其他可选参数如apiserver-advertise-address等]
# 如果需要使用特定的镜像仓库:
# sudo kubeadm init --kubernetes-version=v1.27.0 --image-repository=<你的镜像仓库> ...
初始化完成后,会输出一些用于配置集群和管理工具的命令,请按照提示执行 kubectl
配置以及加入 worker 节点所需的命令。
部署 Pod 网络插件
例如,部署 Calico 网络插件:
bash
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
kubectl apply -f https://docs.projectcalico.org/manifests/calico.yaml
等待 Calico 组件成功运行后,检查 Pod 状态和节点状态以确认集群是否正常:
bash
kubectl get pods --all-namespaces
kubectl get nodes
加入 Worker 节点
在每个工作节点上执行以下命令(从主节点初始化输出中获得)来将其加入到集群:
bash
# 在worker节点上执行
sudo kubeadm join <主节点IP>:<端口> --token <令牌> --discovery-token-ca-cert-hash <哈希值>
以上步骤提供了一个基本的安装流程,但请注意,在实际操作中应参照官方文档并根据具体情况进行调整。同时,务必替换 <主节点IP>
、<端口>
、<令牌>
和 <哈希值>
为实际值。