Kubernetes 集群初步部署
Kubernetes 集群初步部署
目标
本手册旨在指导您在多台虚拟机上部署一个基础的Kubernetes集群,并安装必要的工具和组件。
准备工作
- 确保所有虚拟机已经准备好,并且具有足够的资源来运行Kubernetes集群。
- 虚拟机操作系统版本一致,推荐使用Red Hat 8.x。
- 确保所有虚拟机之间网络互通。
- 推荐主机配置:
主机 | ip | 配置 |
---|---|---|
master | 192.168.3.195 | 4核,6g内存,40g硬盘 |
node1 | 192.168.3.196 | 2核,2g内存,20g硬盘 |
node2 | 192.168.3.197 | 2核,2g内存,20g硬盘 |
步骤
-
修改主机名
- 登录到每台虚拟机。
- 使用
hostnamectl
命令设置主机名。hostnamectl set-hostname master hostnamectl set-hostname node1 hostnamectl set-hostname node2
-
配置阿里源并更新包
- 在每台虚拟机上编辑
/etc/yum.repos.d/aliyun.repo
文件。
添加以下内容:sudo vim /etc/yum.repos.d/aliyun.repo
[baseos] name=CentOS-$releasever-BaseOS-mirrors.aliyun.com baseurl=https://mirrors.aliyun.com/centos/$releasever/BaseOS/$basearch/os/ gpgcheck=0 enabled=1[appstream] name=CentOS-$releasever-AppStream-mirrors.aliyun.com baseurl=https://mirrors.aliyun.com/centos/$releasever/AppStream/$basearch/os/ gpgcheck=0 enabled=1
- 更新包缓存。
sudo dnf makecache sudo dnf update -y
- 在每台虚拟机上编辑
-
配置SSH免密登录
- 在Master节点上生成SSH密钥。
ssh-keygen -t rsa -N "" -f ~/.ssh/id_rsa
- 复制公钥到所有节点。
ssh-copy-id master ssh-copy-id node1 ssh-copy-id node2
- 测试SSH连接。
ssh node1
- 在Master节点上生成SSH密钥。
-
关闭交换分区
- 在所有节点上执行以下命令。
swapoff -a echo "vm.swappiness = 0" >> /etc/sysctl.conf sysctl -p
- 在所有节点上执行以下命令。
-
关闭防火墙
- 在所有节点上执行以下命令。
systemctl disable firewalld systemctl stop firewalld
- 在所有节点上执行以下命令。
-
修改内核参数
- 在所有节点上执行以下命令。
modprobe br_netfilter echo "modprobe br_netfilter" >> /etc/profile tee /etc/sysctl.d/k8s.conf << EOF net.bridge.bridge-nf-call-ip6tables = 1 net.bridge.bridge-nf-call-iptables = 1 EOF sysctl --system
- 在所有节点上执行以下命令。
-
配置集群时间同步
- 在所有节点上安装并启用chrony服务。
sudo dnf install -y chrony systemctl start chronyd systemctl enable chronyd
- 在所有节点上安装并启用chrony服务。
-
配置DNF仓库
- 在所有节点上执行以下命令。
sudo dnf install -y dnf-utils device-mapper-persistent-data lvm2 sudo dnf config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
- 在所有节点上执行以下命令。
-
安装Docker
- 在所有节点上执行以下命令,registry-mirrors此处替换为国内镜像源,如阿里
sudo dnf install -y docker-ce-20.10.0 docker-ce-cli-20.10.0 containerd.io systemctl start docker systemctl enable docker docker version cat > /etc/docker/daemon.json << EOF {"registry-mirrors": ["https://your.mirror.aliyuncs.com"],"exec-opts": ["native.cgroupdriver=systemd"] } EOF systemctl daemon-reload systemctl restart docker
- 在所有节点上执行以下命令,registry-mirrors此处替换为国内镜像源,如阿里
-
添加主节点到hosts文件
- 在所有节点上执行以下命令。
echo "192.168.3.195 cluster-endpoint" >> /etc/hosts
- 在所有节点上执行以下命令。
-
安装Kubernetes
- 在所有节点上创建Kubernetes的YUM仓库。
cat <<EOF > /etc/yum.repos.d/kubernetes.repo [kubernetes] name=Kubernetes baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/ enabled=1 gpgcheck=1 repo_gpgcheck=1 gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg EOF
- 在所有节点上安装Kubernetes组件。
sudo dnf install -y kubelet-1.23.6 kubeadm-1.23.6 kubectl-1.23.6 systemctl enable kubelet
- 在所有节点上创建Kubernetes的YUM仓库。
-
安装CoreDNS
- 在所有节点上执行以下命令。
docker pull coredns/coredns:1.8.4 docker tag coredns/coredns:1.8.4 registry.aliyuncs.com/google_containers/coredns:v1.8.4
- 在所有节点上执行以下命令。
-
初始化Kubernetes集群(仅在Master节点执行)
- 执行以下命令。
kubeadm init \ --apiserver-advertise-address=192.168.3.195 \ --control-plane-endpoint=cluster-endpoint \ --image-repository registry.cn-hangzhou.aliyuncs.com/google_containers \ --service-cidr=10.96.0.0/12 \ --pod-network-cidr=172.20.0.0/16
- 初始化完成后,根据提示信息执行
kubeadm join
命令加入Worker节点。 - 将
kubeconfig
文件复制到用户目录。mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config
- 执行以下命令。
-
复制
kubeconfig
文件到node节点- 使用SSH将
kubeconfig
文件复制到Worker节点。ssh root@node1 'mkdir -p /root/.kube' ssh root@node2 'mkdir -p /root/.kube' scp /etc/kubernetes/admin.conf root@node1:/root/.kube/config scp /etc/kubernetes/admin.conf root@node2:/root/.kube/config ssh root@node1 'chmod 600 /root/.kube/config' ssh root@node2 'chmod 600 /root/.kube/config'
- 使用SSH将
-
验证节点状态
- 在Master节点上执行以下命令。
kubectl get nodeNAME STATUS ROLES AGE VERSION master Ready control-plane,master 3d21h v1.23.6 node1 Ready <none> 3d21h v1.23.6 node2 Ready <none> 3d21h v1.23.6
- 在Master节点上执行以下命令。
-
安装Kuboard图形化工具(仅在Master节点执行)
- 安装Kuboard。
kubectl apply -f https://addons.kuboard.cn/kuboard/kuboard-v3.yaml
- 访问Kuboard。
输入初始用户名和密码登录。http://<master-ip>:30080
- 用户名:admin
- 密码:Kuboard123
- 安装Kuboard。
注意事项
- 确保所有命令都以
sudo
前缀运行,以获得必要的权限。 - 检查网络连接,确保所有节点之间能够互相访问。
- 如果遇到任何问题,请检查日志文件和输出信息,以便进行故障排除。
- 安全性考虑:在生产环境中,强烈建议使用更安全的方法来处理敏感信息,如证书和密钥。
相关文章:
Kubernetes 集群初步部署
Kubernetes 集群初步部署 目标 本手册旨在指导您在多台虚拟机上部署一个基础的Kubernetes集群,并安装必要的工具和组件。 准备工作 确保所有虚拟机已经准备好,并且具有足够的资源来运行Kubernetes集群。虚拟机操作系统版本一致,推荐使用R…...

从源码到成品:直播美颜SDK与主播美颜工具的开发全流程
本篇文章,小编将带你深入了解从源码到成品的开发全流程,探讨如何构建一个功能完善的直播美颜SDK与主播美颜工具。 一、需求分析与技术规划 在开发任何工具之前,需求分析是第一步。在美颜工具的开发过程中,需要明确以下几点&…...

AMD EPYC 9004服务器内存配置深度分析:为何全通道填充是关键?
在一次技术沟通中,客户询问在部署AMD EPYC 9004服务器时,是否应该完全填充内存通道? 考虑到AMD正在用5年的更新周期替换其AMD EPYC 7002 “Rome”和Cascade Lake一代的服务器,他们认为通过减少内存插槽的填充,可以节省…...
redis的事务与管道有什么不同?
Redis 的事务(MULTI/EXEC)和管道(PIPELINE)都是为了执行多条命令,但它们的工作原理和目标不同。以下是两者的详细对比。 1. Redis 事务 (MULTI/EXEC) 特点: 事务的本质:Redis 事务是一组命令的…...
Redis 配置
一、关系型数据库与非关系型数据库 1. 关系型数据库 关系型数据库是一种结构化数据库,基于关系模型(二维表格模型),适合记录数据。通过 SQL(结构化查询语言)进行数据的检索和操作。主流的关系型数据库包括…...

【Qt笔记】QTableWidget控件详解
目录 引言 一、QTableWidget的特点 二、QTableWidget基础 2.1 引入QTableWidget 2.2 基本属性 三、代码示例:初始化QTableWidget 四、编辑功能 4.1 设置单元格为只读 4.2 响应内容更改 五、选择模式 六、样式定制 七、与其他控件的交互 7.1 在单元格…...

高低压配电系统中电弧光的危害有多大?
摘要 故障电弧是一种常见的电气故障现象,尤其在配电系统中,可能对设备安全和电力供应造成严重影响。本文旨在探讨故障电弧对配电系统的危害,并提出相应的预防措施,以增强系统的可靠性和安全性。通过对故障电弧的形成机制、危害分…...

安宝特案例 | AR如何大幅提升IC封装厂检测效率?
前言:如何提升IC封装厂检测效率? 在现代电子产品的制造过程中,IC封装作为核心环节,涉及到复杂处理流程和严格质量检测。这是一家专注于IC封装的厂商,负责将来自IC制造商的晶圆进行保护、散热和导通处理。整个制程繁琐…...

QGIS 如何连接空间库,并实时编辑空间表?编辑后库表如何刷新,保证是最新数据?
文章目录 一、什么是 qgis?二、qgis 如何连接数据库三、实时编辑空间表四、编辑后库表如何刷新,保证是最新数据?五、总结 一、什么是 qgis? QGIS(原称Quantum GIS)是一个用户界面友好的开源桌面端软件&…...

CleanClip for mac(苹果电脑剪切板管理器)
CleanClip 是一款为 Mac 设计的强大剪贴板管理工具,它能够显著提升你的工作效率和生产力。无论是在日常办公中还是进行创意设计,CleanClip 都能帮助你更轻松地管理和使用剪贴板内容。让我们一起来探索一下这个功能丰富的软件吧! 下载地址&am…...

嵌入式栈溢出怎么办?
在写文件的时候,因为把FATFS这些数据结构定义在了函数里,所以栈溢出了,我把比较大的数据结构放在全局变量上,就没事了.目前仅测试阶段,也可以放在堆里.不用的时候释放掉,减少耦合度.或者加static....

工厂安灯系统在优化生产流程上的优势
工厂安灯系统通过可视化的方式,帮助工厂管理者和操作工人及时了解生产状态,快速响应问题,从而优化生产流程。 一、安灯系统实时监控与反馈 安灯系统的核心功能是实时监控生产线的状态。通过在生产现场设置灯光、显示屏等设备,工人…...
【Kubernetes】(K8S)彻底卸载详细教程
以下全部操作都是使用root用户进行(非root用户可以使用sudo),并且全部命令都需要在Kubernetes集群的所有节点分别执行: 第一步、停止K8S 所有节点执行: 1 2 3 systemctl stop kubelet systemctl stop etcd systemct…...

web基础之文件上传
1.下载安装 下载地址 链接:百度网盘-链接不存在 提取码:jhks 安装 直接把他放在phpstudy的WWW目录中。(phpstudy的下载安装,可以自行百度一下) 打开 访问地址:127.0.0.1/upload-labs 问题 这里可能…...

解决“找不到msvcp140.dll无法继续执行代码”问题:技术困境与解决方案
在现代计算机技术的发展中,软件依赖性问题日益凸显,其中“找不到msvcp140.dll无法继续执行代码”错误尤为常见。本文将从技术背景、问题成因、解决方案及预防措施四个方面,深入探讨这一技术困境,旨在为读者提供全面的理解和有效的…...

智能赋能,Vatee万腾平台助力企业升级新高度
在当今这个日新月异的数字时代,智能技术的飞速发展正以前所未有的力量重塑着各行各业的面貌。作为这一变革浪潮中的佼佼者,Vatee万腾平台凭借其卓越的智能赋能能力,正引领众多企业迈向转型升级的新高度,开启了智能化发展的新篇章。…...

ceph-radosgw 手动安装教程以及安装问题解决办法
一、环境 操作系统版本:Ubuntu20.04 x86_64 ceph版本:ceph version 15.2.17 (8a82819d84cf884bd39c17e3236e0632ac146dc4) octopus (stable) radosgw版本:15.2.17 二、ceph-radosgw 安装步骤 ceph官方英文版教程,写了个大概步骤…...
PageRank算法
一.定义-迭代算法 输入:含有 n n n个结点的有向图,转移矩阵 M M M,阻尼因子 d d d,初始向量 R 0 R_0 R0,计算精度 ϵ \epsilon ϵ 输出:有向图的PageRank向量 R R R (1)令 t 0 t0 t0 (2)计算 R t 1 d M R t 1 − d n 1 R_{t1} dMR_t \frac{ 1 - d }{ n} 1 Rt1dMRt…...

YOLOv8改进 | 模块缝合 | C2f 融合Self-Calibrated Convolutions丰富特征图【CVPR2020】
秋招面试专栏推荐 :深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 💡💡💡本专栏所有程序均经过测试,可成功执行💡💡💡 专栏目录 :《YOLOv8改进有效…...

跨境反向代购淘宝京东商品系统的商品价格详情等数据如何轻松自动化获取?
在跨境电商领域,反向代购系统逐渐成为连接国内外市场的重要桥梁。随着技术的不断发展和市场的日益成熟,如何高效、准确地自动化获取淘宝、京东等电商平台的商品价格、详情等数据,成为跨境反向代购系统开发者必须面对的重要课题。本文将详细介…...
Python|GIF 解析与构建(5):手搓截屏和帧率控制
目录 Python|GIF 解析与构建(5):手搓截屏和帧率控制 一、引言 二、技术实现:手搓截屏模块 2.1 核心原理 2.2 代码解析:ScreenshotData类 2.2.1 截图函数:capture_screen 三、技术实现&…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真
目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销,平衡网络负载,延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...
Frozen-Flask :将 Flask 应用“冻结”为静态文件
Frozen-Flask 是一个用于将 Flask 应用“冻结”为静态文件的 Python 扩展。它的核心用途是:将一个 Flask Web 应用生成成纯静态 HTML 文件,从而可以部署到静态网站托管服务上,如 GitHub Pages、Netlify 或任何支持静态文件的网站服务器。 &am…...
spring:实例工厂方法获取bean
spring处理使用静态工厂方法获取bean实例,也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下: 定义实例工厂类(Java代码),定义实例工厂(xml),定义调用实例工厂ÿ…...

C# 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...

【 java 虚拟机知识 第一篇 】
目录 1.内存模型 1.1.JVM内存模型的介绍 1.2.堆和栈的区别 1.3.栈的存储细节 1.4.堆的部分 1.5.程序计数器的作用 1.6.方法区的内容 1.7.字符串池 1.8.引用类型 1.9.内存泄漏与内存溢出 1.10.会出现内存溢出的结构 1.内存模型 1.1.JVM内存模型的介绍 内存模型主要分…...

关于easyexcel动态下拉选问题处理
前些日子突然碰到一个问题,说是客户的导入文件模版想支持部分导入内容的下拉选,于是我就找了easyexcel官网寻找解决方案,并没有找到合适的方案,没办法只能自己动手并分享出来,针对Java生成Excel下拉菜单时因选项过多导…...
Docker拉取MySQL后数据库连接失败的解决方案
在使用Docker部署MySQL时,拉取并启动容器后,有时可能会遇到数据库连接失败的问题。这种问题可能由多种原因导致,包括配置错误、网络设置问题、权限问题等。本文将分析可能的原因,并提供解决方案。 一、确认MySQL容器的运行状态 …...
土建施工员考试:建筑施工技术重点知识有哪些?
《管理实务》是土建施工员考试中侧重实操应用与管理能力的科目,核心考查施工组织、质量安全、进度成本等现场管理要点。以下是结合考试大纲与高频考点整理的重点内容,附学习方向和应试技巧: 一、施工组织与进度管理 核心目标: 规…...
【实施指南】Android客户端HTTPS双向认证实施指南
🔐 一、所需准备材料 证书文件(6类核心文件) 类型 格式 作用 Android端要求 CA根证书 .crt/.pem 验证服务器/客户端证书合法性 需预置到Android信任库 服务器证书 .crt 服务器身份证明 客户端需持有以验证服务器 客户端证书 .crt 客户端身份…...