使用二进制文件方式部署kubernetes(1)

使用二进制文件方式部署kubernetes(1)

OS:OpenEuler-24.03

ip规划

规划好master以及worker节点数量,推荐master节点数为奇数

安装必备工具

所有节点执行

bash 复制代码
dnf -y install  wget psmisc vim net-tools nfs-utils telnet device-mapper-persistent-data lvm2 git tar curl bash-completion

部分工具功能:

psmisc:进程管理工具,包括pstree、killall、fuser,可以以树状图查看进程,可以杀死进程,可以查看哪些进程在使用指定文件

net-tools:ifconfig netstat route那些网络工具

device-mapper-persistent-data:通常和lvm2一起安装,提供持久化数据存储库,是Docker的存储驱动

lvm2:管理逻辑卷,可以创建、调整大小、删除逻辑卷

bash-completion:就是bash的tab补全功能

关闭防火墙和SElinux

所有节点执行

bash 复制代码
systemctl disable --now firewalld
setenforce 0
sed -i 's#SELINUX=enforcing#SELINUX=disabled#g' /etc/selinux/config

一般来说k8s部署在内部网络,如果选择不关闭防火墙和SElinux则需要配置防火墙开放针对性的端口

例如api-server端口6443

bash 复制代码
firewall-cmd --permanent --add-port=6443/tcp

但是内部网络的话一般都能被边界防火墙保护,若是云环境也可以设置相关安全组和ACL,那么为方便操作则关闭防火墙和SElinux,但众所周知 方便 和 安全 难以兼得

关闭交换分区

所有节点执行

bash 复制代码
sed -ri 's/.*swap.*/#&/' /etc/fstab
swapoff -a && sysctl -w vm.swappiness=0
cat /etc/fstab

因为k8s要精确的知道各个节点有多少可用内存来调度Pod,这里的内存不能算上Swap,(Swap就是把磁盘空间一部分当作虚拟内存来用),因为Swap速度慢,可能造成"磁盘抖动",导致pod性能突然下降

最后输出要出现如下所示才修改成功

网络配置

所有节点执行

创建calico.conf

bash 复制代码
vim /etc/NetworkManager/conf.d/calico.conf

写入

bash 复制代码
[keyfile]
unmanaged-devices=interface-name:cali*;interface-name:tunl*

这是为后面使用calico作为CNI插件做准备,让NetworkManager不要管calico创建的接口,calico会自己管,否则可能会导致Pod生命周期错误,ip地址冲突、路由表混乱

时间同步

OpenEuler默认已经安装并开启chrony时间同步服务,如果没有安装则根据自己系统来选择安装命令

各个节点都要安装

bash 复制代码
# RedHat/CentOS 7/8/9
sudo yum install -y chrony

# Ubuntu/Debian
sudo apt update
sudo apt install -y chrony

# Fedora
sudo dnf install -y chrony

# openSUSE
sudo zypper install -y chrony

# 验证安装
chronyc --version

# 开启服务并设置开机自启
systemctl start chronyd # 注意末尾多个d
systemctl enable chronyd

# 查看服务状态
systemctl status chronyd

配置时间同步服务器,选择master1作为时间同步服务器

在master1上执行

bash 复制代码
vim /etc/chrony.conf

修改行数为23、26、32、41这四处地方,其中23行要改成自己的网段

重启chrony使修改生效

bash 复制代码
systemctl restart chronyd

配置客户机,也就是除master1以外所有节点

bash 复制代码
vim /etc/chrony.conf

修改行数3、32、41行内容,其中3行要修改我时间同步服务器ip,这里是master1ip

重启chrony

bash 复制代码
systemctl restart chronyd

验证配置

bash 复制代码
chronyc sources

配置ulimit

所有节点执行

bash 复制代码
ulimit -SHn 65535# 临时设置
bash 复制代码
vim /etc/security/limits.conf

在末尾添加

bash 复制代码
# 一般用户:(*表示除root外所有用户)
* soft nofile 1024        # 一般用户可打开的文件数
* hard nofile 65536
* soft nproc 1024         # 一般用户可运行的进程数
* hard nproc 4096
* soft memlock 65536      # 允许一般用户进程锁定内存在物理ram中的大小
* hard memlock 65536

# root用户:
root soft nofile 1048576  # 1M,运行K8s足够
root hard nofile 1048576
root soft nproc unlimited # 无限制
root hard nproc unlimited
root soft memlock unlimited
root hard memlock unlimited

因为k8s各组件由root用户运行,所以要限制普通用户的资源使用,以免影响k8s资源使用

配置ssh免密登录

在master1执行

bash 复制代码
ssh-keygen -f /root/.ssh/id_rsa -P ''
#以下ip需要替换成自己节点的ip
export IP="192.168.153.161 192.168.153.162 192.168.153.163 192.168.153.181 192.168.153.182"
export SSHPASS=your_password #root账户密码,且各节点root账户密码要相同
#安装sshpass
dnf install sshpass -y
for HOST in $IP;do sshpass -e ssh-copy-id -o StrictHostKeyChecking=no $HOST; done

配置master1可以免密ssh连接各节点,方便后续的文件传输

配置IPVS

IPVS(IP Virtual Server)是Linux内核内置的高性能负载均衡器,它替代Kubernetes默认的iptables模式来处理Service的流量分发。相比iptables,IPVS能显著提升大规模集群中Service的访问性能,并提供更丰富的监控指标和更好的连接管理能力

所有节点执行

bash 复制代码
vim /etc/modules-load.d/ipvs.conf

写入以下内容

bash 复制代码
ip_vs
ip_vs_rr
ip_vs_wrr
ip_vs_sh
nf_conntrack
ip_tables
ip_set
xt_set
ipt_set
ipt_rpfilter
ipt_REJECT
ipip

重启服务

bash 复制代码
systemctl restart systemd-modules-load.service

查看内核模块来验证配置生效

bash 复制代码
lsmod | grep -e ip_vs -e nf_conntrack
相关推荐
农民工老王1 小时前
K8s 1.31 私有化部署实战:从 Calico 崩溃到 NFS 挂载失败的排坑全记录
云原生·kubernetes
广州中轴线1 小时前
OpenStack on Kubernetes 生产部署实战(十四)
kubernetes·智能路由器·openstack
m0_694845571 小时前
tinylisp 是什么?超轻量 Lisp 解释器编译与运行教程
服务器·开发语言·云计算·github·lisp
ESBK20252 小时前
第四届移动互联网、云计算与信息安全国际会议(MICCIS 2026)二轮征稿启动,诚邀全球学者共赴学术盛宴
大数据·网络·物联网·网络安全·云计算·密码学·信息与通信
_运维那些事儿15 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
人间打气筒(Ada)18 小时前
k8s:CNI网络插件flannel与calico
linux·云原生·容器·kubernetes·云计算·k8s
江畔何人初19 小时前
pod的内部结构
linux·运维·云原生·容器·kubernetes
苦逼IT运维1 天前
从 0 到 1 理解 Kubernetes:一次“破坏式”学习实践(一)
linux·学习·docker·容器·kubernetes
腾讯云开发者1 天前
言出法随 -- Chaterm如何通过ASR精准操作K8S
云原生·容器·kubernetes
主机哥哥1 天前
2026年阿里云五种方案快速部署 OpenClaw(Clawdbot)详细教程
阿里云·云计算