在 CentOS 7 上使用 kubeadm 安装 Kubernetes 1.27安装指导

环境准备

更新系统并安装依赖包
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><端口><令牌><哈希值> 为实际值。

相关推荐
岁岁种桃花儿11 小时前
kubenetes从入门到上天系列第二十一篇:Kubernetes安装Ingress实战
云原生·容器·kubernetes
http阿拉丁神猫20 小时前
kubernetes知识点汇总19~24
云原生·容器·kubernetes
切糕师学AI20 小时前
K8s中的控制器模式(Controller Pattern)
容器·kubernetes
sanyii31313120 小时前
k8s工作负载-Deployment的参数与灰度发布
云原生·容器·kubernetes
道清茗21 小时前
【Kubernetes知识点问答题】常规维护管理操作 / ETCD 备份与恢复
docker·kubernetes·etcd
lpruoyu21 小时前
【云原生】Kubernetes平台存储系统搭建_CRI、CNI、CSI
ceph·云原生·容器·kubernetes
道清茗1 天前
【Kubernetes知识点问答题】Kustomize、CRD 与 Gateway API
容器·kubernetes·gateway
专注_每天进步一点点1 天前
流量从bcop网关到apisixroute,再到应用的gateway模块,再到其他服务
docker·kubernetes·gateway
龙飞051 天前
Kubernetes 疑难杂症:Pod 始终处于 Terminating 状态的真实原因与安全修复方案
安全·云原生·容器·kubernetes
MonkeyKing_sunyuhua1 天前
K8S执行MAC打出的本地镜像错误:exec /usr/local/bin/uvicorn: exec format error
macos·容器·kubernetes