当前位置: 首页 > news >正文

K8S (Containerd)初始化安装流程

Highlight:
一定要注意Containerd+ kubeadm+Linux内核的兼容性,初次尝试在Ubuntu24.04,内核 6.8.0 上安装,出现kube apiserver 不断重启的问题。切换到5.15内核后问题解决。
本次安装版本如下:
containerd: 1.6.31
Kubernetes v1.28.2
操作系统: Ubuntu 20.04
内核: 5.15.0-1089-azure

-------所有节点(Master+Node)---------------

1.执行初始化脚本
用google的资源库会有一些问题,切换到aliyun
脚本如下:

!/bin/bash

所有节点通用初始化脚本

设置网络参数

sudo tee /etc/sysctl.d/k8s.conf <<EOT
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv4.ip_forward = 1
EOT

echo "net.ipv4.ip_forward = 1" | sudo tee -a /etc/sysctl.conf
sudo sysctl -p

更新系统

sudo apt update && sudo apt upgrade -y

关闭 swap

sudo swapoff -a
net.bridge.bridge-nf-call-ip6tables = 1
EOF

sudo sysctl --system

安装 containerd

sudo apt update
sudo apt install -y ca-certificates curl gnupg lsb-release

sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg

echo
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu
$(lsb_release -cs) stable" |
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

sudo apt update

sudo apt install -y containerd.io=1.6.31-1
sudo apt-mark hold containerd.io
sudo mkdir -p /etc/containerd
containerd config default | sudo tee /etc/containerd/config.toml

修改 pause 镜像为阿里云源,并且修改sandbox_image 为3.9 来和kubectl match

sudo sed -i 's|sandbox_image = .*|sandbox_image = "registry.aliyuncs.com/google_containers/pause:3.9"|' /etc/containerd/config.toml

sudo systemctl restart containerd
sudo systemctl enable containerd

添加阿里云 Kubernetes APT 源

cat <<EOF | sudo tee /etc/apt/sources.list.d/kubernetes.list
deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main
EOF

curl -s https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | sudo apt-key add -

安装 Kubernetes 工具

sudo apt update
sudo apt install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectlsudo sed -i '/ swap / s/^/#/' /etc/fstab

加载内核模块

cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf
overlay
br_netfilter
EOF

sudo modprobe overlay
sudo modprobe br_netfilter

--------Master节点---------------

2,执行init 命令进行muster的初始化
sudo kubeadm init --apiserver-advertise-address=MasterIP --pod-network-cidr=yourpodsubnet
3.设置admin.conf
mkdir -p $HOME/.kube
sudo cp /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u)😒(id -g) $HOME/.kube/config
4.安装 flannel 网络组件
kubectl apply -f https://github.com/flannel-io/flannel/releases/latest/download/kube-flannel.yml
5.查看node 情况
kubectl get nodes
6.查看 kube 进程状态
azureuser@master01:~$ sudo crictl --runtime-endpoint unix:///var/run/containerd/containerd.sock ps -a | grep kube

-----------Node节点--------------
1.初始化后,用master初始化生成的注册脚本进行注册

kubeadm join MasterIP:6443 --token token
--discovery-token-ca-cert-hash sha256xxxxx

2.查看kube各个进程的情况
sudo crictl --runtime-endpoint unix:///var/run/containerd/containerd.sock ps -a | grep kube
3.查看kubelet的情况
sudo systemctl status kubelet

http://www.hskmm.com/?act=detail&tid=16215

相关文章:

  • ?模拟赛 赛后总结
  • 日志|动态规划|最长回文子串|最长公共子序列|HTML CSS
  • Java 字段命名避坑: success和isSuccess
  • OTA升级时软件异常复位问题分析
  • Atcoder Educational DP Contest 做题记录
  • 20250924
  • 跨端边云时序数据管理新范式:Apache IoTDB 的 DB+AI 融合之道 - 实践
  • 《Real-Time Rendering》第二章 图形渲染管线
  • 放弃Unity后,我为什么选择了Unigine?
  • PHP 与 Java 的终极对比:2025年,开发者该如何选择? - 详解
  • 题单63——流程控制
  • 银行同业存单的信用等级
  • 软件技术基础第一次作业
  • 2025XDOJ个人题解——写在前面
  • 适合电子纸屏幕的简易象棋打谱程序
  • 0924
  • java_string比较中的细节
  • 扫描线学习笔记
  • go-reids
  • AI完美声音克隆及情绪控制,与真人无异,Lark下载介绍
  • WSL,适用于 Linux 的 Windows 子系统
  • 9-24
  • 代码随想录算法训练营第八天 |344.反转字符串、541. 反转字符串II、LCR 122. 路径加密
  • 9/24
  • 安装与卸载JDK8
  • mysql慢sql配置
  • Linux zdb -C (zfs Debugger调试器)
  • 从零开始实现简易版Netty(八) MyNetty 实现Small规格的池化内存分配
  • 测试脚本
  • 自动化测试脚本