在 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><端口><令牌><哈希值> 为实际值。

相关推荐
helloworddm4 小时前
Orleans + Kubernetes + Istio 服务网格集成深度解析
容器·kubernetes·istio
小彭律师4 小时前
Docker/K8s部署MySQL的创新实践与优化技巧大纲
mysql·docker·kubernetes
旦沐已成舟6 小时前
K8S搭建轻量级日志收集系统(EFK)
elk·kubernetes
thinktik8 小时前
AWS EKS安装S3 CSI插件[AWS 海外区]
后端·kubernetes·aws
Jy_06229 小时前
K8s中,deployment 是如何从 yaml 文件最终部署成功 pod 的
云原生·容器·kubernetes
mobº9 小时前
K8s 集群环境搭建 - yaml 版本(一)
云原生·容器·kubernetes
终端行者9 小时前
K8s中部署Minio集群 如何部署minio集群
云原生·容器·kubernetes·1024程序员节
荣光波比9 小时前
Prometheus(二)—— 在K8s集群中部署Prometheus+Grafana+AlertManager实现全方位监控
kubernetes·grafana·prometheus
StarRocks_labs13 小时前
Kubernetes 场景下的 StarRocks 灾备体系:Cluster Snapshot 实践解析
starrocks·kubernetes·数据备份·存算一体架构·快照恢复机制
thinktik13 小时前
AWS EKS 计算资源自动扩缩之Fargate[AWS 海外区]
后端·kubernetes·aws