当前位置: 首页 > 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.gsyq.cn/news/11174.html

相关文章:

  • Java 字段命名避坑: success和isSuccess
  • 跨端边云时序数据管理新范式:Apache IoTDB 的 DB+AI 融合之道 - 实践
  • PHP 与 Java 的终极对比:2025年,开发者该如何选择? - 详解
  • 银行同业存单的信用等级
  • go-reids
  • WSL,适用于 Linux 的 Windows 子系统
  • 学财税大信息应用,需要考CPA/税务师吗?
  • APM v4.1.1 | 免费音乐听歌B站油管音乐播放器 - 指南
  • 安装与卸载JDK8
  • Linux zdb -C (zfs Debugger调试器)
  • 从零开始实现简易版Netty(八) MyNetty 实现Small规格的池化内存分配
  • 解题报告-字符串(str.*)
  • Linux 系统中的 /dev/disk/by-id/目录作用详解
  • 3.HTTP/HTTPS:报文格式、技巧、状态码、缓存、SSLTLS握手
  • keepalived服务器
  • 封神台复现
  • 李之一的Java第一作
  • 第三篇
  • 基于cloacked-pixel隐写工具爆破项目
  • redis 大 key 优化。哈罗面试:redis 有个大 key需要在线优化, 不能影响现有业务,请求不能大量到库,怎么优化?
  • ACL高可用架构。希音面试:第三方挂了,我们总在背锅。来一 靠谱的 高可用方案,让 外部依赖 稳如泰山
  • 【星海随笔】RabbitMQ开发篇 - 教程
  • Playwright MCP 服务器对比高层级的 MCP 服务器解决方案 - 详解
  • P13754 【MX-X17-T3】Distraction
  • 初学汇编
  • C++、Java 和 Python 在输入输出差别
  • 用 Java 和 Tesseract 进行验证码识别:基础实现与优化
  • 详细介绍:【2025PolarCTF秋季个人赛】WEB方向wp
  • 普通用户之间免密互信时因权限问题致使配置失败
  • 深入解析:[p2p-Magnet] docs | HTTP API与Web界面 | 搜索查询引擎