Rocky Linux 8.9配置Kubernetes集群详解,适用于CentOS环境

在配置基于Rocky Linux 8.9的Kubernetes集群时,您需要遵循一系列具体的步骤以确保集群的稳定性和性能。以下是这一过程的概要:

系统环境设置

1. 系统更新:

首先,确保所有节点更新到最新版本。

复制代码
sudo dnf update -y
sudo reboot
​

2. 主机名设置:

每个节点都需要一个唯一的主机名。

复制代码
sudo hostnamectl set-hostname <hostname>
​

例如,master节点可设为 master-node,工作节点可设置为 worker-node1worker-node2等。

3. 配置hosts文件:

在所有节点上配置 /etc/hosts

复制代码
<master-ip> master-node
<worker1-ip> worker-node1
<worker2-ip> worker-node2
​

4. 禁用SELinux:

由于SELinux可能与容器运行时产生冲突,因此建议将其禁用。

复制代码
sudo setenforce 0
sudo sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config
​

5. 关闭Swap:

为了Kubernetes正常运行,需要关闭swap。

复制代码
sudo swapoff -a
sudo sed -i '/ swap / s/^(.*)$/#\1/g' /etc/fstab
​

6. 防火墙设置:

建议暂时关闭防火墙,以简化部署过程。

复制代码
sudo systemctl stop firewalld
sudo systemctl disable firewalld
​

安装Docker和Kubernetes

1. 安装Docker引擎:

Kubernetes要求存在容器运行环境,Docker是一个流行的选择。

复制代码
sudo dnf config-manager --add-repo=https://download.docker.com/linux/centos/docker-ce.repo
sudo dnf install docker-ce docker-ce-cli containerd.io -y
sudo systemctl start docker
sudo systemctl enable docker

2. 配置Docker Cgroup驱动:

Kubernetes推荐使用 systemd作为cgroup驱动。

复制代码
sudo mkdir /etc/docker
cat <<EOF | sudo tee /etc/docker/daemon.json
{
  "exec-opts": ["native.cgroupdriver=systemd"]
}
EOF
sudo systemctl restart docker

3. 添加Kubernetes仓库:

复制代码
cat <<EOF | sudo tee /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://packages.cloud.google.com/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
exclude=kube*
EOF

4. 安装Kubernetes组件:

复制代码
sudo dnf install -y kubelet kubeadm kubectl --disableexcludes=kubernetes
sudo systemctl enable --now kubelet

初始化Kubernetes集群

1. 初始化主节点:

在master节点上执行以下命令来初始化集群:

复制代码
sudo kubeadm init --pod-network-cidr=10.244.0.0/16

初始化成功后,记录下显示的 kubeadm join命令。

相关推荐
sim2020几秒前
把某个pod固定到某个节点
kubernetes
OliverH-yishuihan8 分钟前
开发linux项目-在 Windows 上 基于“适用于 Linux 的 Windows 子系统(WSL)”
linux·c++·windows
南棱笑笑生2 小时前
20251224给飞凌OK3588-C开发板适配Rockchip原厂的Buildroot【linux-6.1】系统时确认ssh服务【内置dropbear】
linux·c语言·ssh·rockchip
I · T · LUCKYBOOM2 小时前
30.Firewalld-Linux
linux·运维·安全
沙滩小绵羊2 小时前
Linux常见命令
linux·运维·服务器
驰羽2 小时前
NAT模式下VMware的虚拟机DNS解析失败的问题解决
linux·网络·dns
菜鸡00013 小时前
安装G2O
linux
誰能久伴不乏3 小时前
epoll 学习踩坑:`fcntl` 设置非阻塞到底用 `F_SETFL` 还是 `F_SETFD`?
linux·服务器·网络·c++·tcp/ip
来鸟 鸣间4 小时前
MIPI D-PHY 理解
linux·音视频·sensor·mipi
么么...4 小时前
在 Ubuntu 上安装 Docker 并部署 MySQL 容器
linux·运维·经验分享·笔记·mysql·ubuntu·docker