3台4核16G机器搭建K8S集群

在三台具有4核16GB内存的机器上安装Kubernetes(K8s)集群涉及到几个关键步骤。我们将一个机器设为主节点(Master)和两个工作节点(Worker)。以下是详细步骤:

1. 系统环境准备(在所有机器上执行)

更新系统
bash 复制代码
sudo yum update -y
关闭Swap

Kubernetes需要关闭Swap以正常工作。

bash 复制代码
sudo swapoff -a

要永久禁用Swap,编辑 /etc/fstab 文件,注释掉swap相关的行。

关闭SELinux

SELinux可能会与Kubernetes组件发生冲突。

bash 复制代码
sudo setenforce 0
sudo sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config
关闭防火墙
bash 复制代码
sudo systemctl stop firewalld
sudo systemctl disable firewalld
设置主机名

为每台机器设置一个唯一的主机名。

bash 复制代码
sudo hostnamectl set-hostname <master-or-worker-node-name>
更新主机文件

确保 /etc/hosts 文件包含所有节点的正确的主机名和IP地址。

2. 安装Docker(在所有机器上执行)

安装Docker
bash 复制代码
sudo yum install -y yum-utils
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
sudo yum install -y docker-ce docker-ce-cli containerd.io
启动并启用Docker
bash 复制代码
sudo systemctl start docker
sudo systemctl enable docker

3. 安装Kubernetes(在所有机器上执行)

添加Kubernetes仓库
bash 复制代码
cat <<EOF | sudo tee /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
安装Kubernetes组件
bash 复制代码
sudo yum install -y kubelet kubeadm kubectl --disableexcludes=kubernetes
启动kubelet
bash 复制代码
sudo systemctl enable --now kubelet

4. 初始化Kubernetes集群(只在主节点上执行)

初始化集群
bash 复制代码
sudo kubeadm init --pod-network-cidr=192.168.0.0/16

记下 kubeadm join 命令的输出,将用于加入工作节点。

设置kubectl(只在主节点上执行)
bash 复制代码
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
安装网络插件(只在主节点上执行)

例如,安装Calico。

bash 复制代码
kubectl apply -f https://docs.projectcalico.org/manifests/calico.yaml

5. 将工作节点加入集群(在每个工作节点上执行)

使用在初始化主节点时提供的 kubeadm join 命令来加入工作节点。

6. 验证集群状态(在主节点上执行)

bash 复制代码
kubectl get nodes

所有节点的状态应该是 Ready

这样,你的Kubernetes集群就建立完成了。根据你的具体需求,可以在此基础上部署各种应用。记得定期检查和维护集群以确保其安全和高效运行。

相关推荐
容器魔方2 小时前
KCD 杭州站 x OpenInfra Days China首次联手!华为云云原生团队与您共探Karmada多模板工作负载多集
云原生·容器·云计算
xx.ii3 小时前
k8s:pod-1
云原生·容器·kubernetes
weixin_307779133 小时前
利用 AWS Lambda 与 EventBridge 优化低频 Java 作业的云计算成本
java·开发语言·云原生·云计算·aws
期待のcode3 小时前
Docker容器
java·docker·容器
TG:@yunlaoda360 云老大4 小时前
火山引擎升级AI云原生套件:AgentKit、ServingKit、TrainingKit全链路加速AI应用落地
人工智能·云原生·火山引擎
容器魔方5 小时前
华为云 Serverless 云原生基础设施 | 极简体验,加速业务创新
云原生·开源·云计算
R-G-B6 小时前
【P7】docker镜像发布和部署
运维·docker·容器·docker镜像·docker镜像发布和部署·镜像发布和部署·docker镜像发布
研究司马懿6 小时前
【ETCD】ETCD集群部署(TLS)
数据库·chrome·云原生·自动化·运维开发·etcd
hu1j6 小时前
[HTB] 靶机学习(十二)Eureka
学习·安全·web安全·网络安全·云原生·eureka
没有bug.的程序员6 小时前
Eureka 注册中心原理与服务注册发现机制
java·spring·云原生·eureka·架构·注册中心·服务注册发现