百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Kubernetes Linux安装指南

nanshan 2025-04-26 19:48 12 浏览 0 评论

在Linux系统上安装Kubernetes通常需要以下步骤。这里以 Ubuntu 20.04/22.04CentOS 7/8 为例:


一、准备工作

  1. 关闭交换分区(Swap)
    Kubernetes默认要求禁用Swap,修改 /etc/fstab 注释swap行,并执行:

bash

sudo swapoff -a # 临时关闭

sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab # 永久关闭

  1. 配置主机名和Hosts解析
    确保每个节点有唯一的主机名,并在 /etc/hosts 中添加解析:

bash

sudo hostnamectl set-hostname master-node # 主节点

sudo hostnamectl set-hostname worker-node1 # 工作节点

# 编辑 /etc/hosts

192.168.1.100 master-node

192.168.1.101 worker-node1

  1. 允许iptables检查桥接流量
    加载内核模块并配置sysctl:

bash

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

overlay

br_netfilter

EOF


sudo modprobe overlay

sudo modprobe br_netfilter


cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf

net.bridge.bridge-nf-call-iptables = 1

net.bridge.bridge-nf-call-ip6tables = 1

net.ipv4.ip_forward = 1

EOF

sudo sysctl --system


二、安装容器运行时(Container Runtime)

选项1:安装Docker

bash

# Ubuntu

sudo apt-get update

sudo apt-get install -y docker.io

sudo systemctl enable --now docker


# CentOS

sudo yum install -y docker

sudo systemctl enable --now docker


# 配置Docker使用systemd作为cgroup驱动

sudo cat <<EOF | sudo tee /etc/docker/daemon.json

{

"exec-opts": ["native.cgroupdriver=systemd"]

}

EOF

sudo systemctl restart docker

选项2:安装containerd

bash

# 安装containerd

sudo apt-get update

sudo apt-get install -y containerd

sudo mkdir -p /etc/containerd

containerd config default | sudo tee /etc/containerd/config.toml

sudo systemctl restart containerd


三、安装Kubernetes组件(kubeadm, kubelet, kubectl)

1. 添加Kubernetes仓库

Ubuntu/Debian:

bash

sudo apt-get update

sudo apt-get install -y apt-transport-https ca-certificates curl

curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.28/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg

echo 'deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.28/deb/ /' | sudo tee /etc/apt/sources.list.d/kubernetes.list

sudo apt-get update

CentOS/RHEL:

bash

cat <<EOF | sudo tee /etc/yum.repos.d/kubernetes.repo

[kubernetes]

name=Kubernetes

baseurl=https://pkgs.k8s.io/core:/stable:/v1.28/rpm/

enabled=1

gpgcheck=1

gpgkey=https://pkgs.k8s.io/core:/stable:/v1.28/rpm/repodata/repomd.xml.key

EOF

2. 安装组件

bash

# Ubuntu/Debian

sudo apt-get install -y kubelet kubeadm kubectl

sudo apt-mark hold kubelet kubeadm kubectl # 阻止自动更新


# CentOS/RHEL

sudo yum install -y kubelet kubeadm kubectl

sudo systemctl enable --now kubelet


四、初始化Kubernetes集群(仅主节点)

bash

sudo kubeadm init \


--apiserver-advertise-address=192.168.1.100 \ # 主节点IP

--image-repository
registry.aliyuncs.com/google_containers \ # 使用阿里云镜像

--pod-network-cidr=10.244.0.0/16 # 与网络插件匹配(如Flannel)


# 初始化成功后,按提示配置kubectl

mkdir -p $HOME/.kube

sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config

sudo chown $(id -u):$(id -g) $HOME/.kube/config


五、安装网络插件(如Calico或Flannel)

示例:安装Calico

bash

kubectl apply -f https://raw.githubusercontent.com/projectcalico/calico/v3.26.1/manifests/calico.yaml

示例:安装Flannel

bash

kubectl apply -f https://github.com/flannel-io/flannel/releases/latest/download/kube-flannel.yml


六、加入工作节点

在主节点初始化成功后,会输出类似以下命令,在工作节点执行:

bash

sudo kubeadm join 192.168.1.100:6443 \

--token <token> \

--discovery-token-ca-cert-hash <hash>


七、验证集群状态

bash

kubectl get nodes # 查看节点状态

kubectl get pods -A # 查看所有Pod


常见问题

  1. 镜像拉取失败
    使用 --image-repository registry.aliyuncs.com/google_containers 指定国内镜像源。
  2. 节点状态为NotReady
    检查网络插件是否安装成功,或防火墙是否开放必要端口(如6443、2379-2380等)。
  3. 单节点集群(测试用)
    若只有主节点,解除污点以允许调度Pod:

bash

kubectl taint nodes --all node-role.kubernetes.io/control-plane-


完成以上步骤后,Kubernetes集群即可正常运行!

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: