使用 Rancher 安装 K8s 集群
舞台环境
- Ubuntu 22.04.2 LTS
- Docker 24.0.2
- 2GB RAM或者更多
- CPU 2核心或者更多
- Rancher 2.6.9
测试环境中,我准备了两台 Ubuntu 服务器,IP分别是 192.168.10.43 和 192.168.10.42,一台用做 k8s 的 master 节点,一台 note 节点,Rancher 和 master 节点公用一台主机。另外,服务器之间的时间一定要精准同步。可以使用在网上找找资料,怎么做到局域网内服务器时间同步。
前置操作
修改主机名
k8s 集群中,不允许出现重复的主机名,所以我们先要修改主机名:
192.168.10.43:
hostnamectl set-hostname master-1
192.168.10.42:
hostnamectl set-hostname node-1
关闭 Swap
关闭 Swap 是保障 k8s 正常运行的不可省略的一部,执行此命令来关闭 Swap:
sed -ri 's/.swap./#&/' /etc/fstab
配置 docker 代理
为了保证后续操作的镜像拉取成功,请配置一下 docker 代理。编辑 /etc/docker/daemon.json,如果该文件不存在,需要先创建。daemon.json 内容如下:
{
"registry-mirrors": [
"https://ung2thfc.mirror.aliyuncs.com",
"https://registry.docker-cn.com",
"http://hub-mirror.c.163.com",
"https://docker.mirrors.ustc.edu.cn"
]
}
重启 docker 使配置生效:
systemctl restart docker
最后重启服务器,确保所有的配置成功生效,这不一定要做,防止出现意外情况。
安装 Rancher
Rancher 只是 k8s 的一个 UI 管理工具,所以一定不要和 k8s 混淆了,Rancher 哪怕宕机了,K8s 也是可以正常运行的。我这里是测试环境,会使用 Docker 部署 Rancher,在实际的生产环境中,建议使用采用其他方式安装 Rancher,请参考官方文档,如果这里你只是学习使用,那么就照着继续做就ok。
在 192.168.10.43 上执行命令,安装 Rancher 2.6.9:
docker run -d --restart=unless-stopped \
--name=rancher \
-p 80:80 -p 443:443 \
--privileged \
rancher/rancher:v2.6.9
Rancher 的安装时间比较长,可以使用该命令查看安装进度:
docker logs --tail 30 -f rancher
等待安装完成后,在浏览器访问 http://IP 即可看到效果:

照着 Rancher 的指引,使用命令获取初始密码,然后重置密码,登录到主页:
docker logs rancher 2>&1 | grep "Bootstrap Password:"

看到这个页面,代表我们的 Rancher 就已经安装成功了,接下来我们来安装 k8s。
安装 k8s
在主页上创建一个集群,选择自定义选项,然后填写好集群名字,其他配置暂且不动,直接下一步即可:


最后会看到这个页面:

每个 K8s 集群最少得有一个 master 节点,我们勾选 Etcd 和 Control,复制生成好的命令在 192.168.10.43 执行,即可部署一个 master 节点,需要哪个主机成为 master 节点,就在其上执行此 docker run 命令,需要多少个 master ,就执行多少次。
这一步会拉取大量的 Dokcer 镜像,部署大量的容器,所以所需时间较长,请耐心等待。在配置过程中,可以点击菜单-集群管理-进入创建的集群,在配置日志中查看安装进度:

完成安装后,使用 docker ps 可以看到很多容器:

部署 note 节点
部署 note 节点比 master 节点简单一点点,在注册面板中把 Etcd 和 Control 勾掉,执行生成的 docker run 命令,就可以部署一个 note 节点,同样,需要多少个 note ,就在多少台主机上 docker run 一下就 ok:

部署完成的效果,可以看到我们一主一从的 k8s 集群:

测试集群
我们来创建一个工作负载,运行一个 nginx,看一下最终效果。进入集群,创建 Deployment ,配置好映射端口、镜像,点击创建:

等待安装完成,在浏览器访问 http://IP:30080, 即可看到 nginx 的欢迎页面。配置 k8s 需要更进一步的学习,本文介绍 Rancher 安装 k8s,不再赘述 k8s 的使用。
使用 Rancher 安装 K8s 集群的更多相关文章
- [k8s]kubespray(ansible)自动化安装k8s集群
kubespray(ansible)自动化安装k8s集群 https://github.com/kubernetes-incubator/kubespray https://kubernetes.io ...
- 使用kubeadm安装k8s集群故障处理三则
最近在作安装k8s集群,测试了几种方法,最终觉得用kubeadm应该最规范. 限于公司特别的网络情况,其安装比网上不能访问google的情况还要艰难. 慢慢积累经验吧. 今天遇到的三则故障记下来作参考 ...
- rancher导入k8s集群后添加监控无数据
1.日志报错 rancher导入k8s集群后添加监控无数据,rancher日志报错: k8s.io/kube-state-metrics/pkg/collectors/builder.go:: Fai ...
- yum安装k8s集群
k8s的安装有多种方式,如yum安装,kubeadm安装,二进制安装等.本文是入门系列,只是为了快速了解k8s的原理和工作过程,对k8s有一个快速的了解,这里直接采用yum安装 的1.5.2为案例进行 ...
- kubernetes教程第一章-kubeadm高可用安装k8s集群
目录 Kubeadm高可用安装k8s集群 kubeadm高可用安装1.18基本说明 k8s高可用架构解析 kubeadm基本环境配置 kubeadm基本组件安装 kubeadm集群初始化 高可用Mas ...
- 冰河教你一次性成功安装K8S集群(基于一主两从模式)
写在前面 研究K8S有一段时间了,最开始学习K8S时,根据网上的教程安装K8S环境总是报错.所以,我就改变了学习策略,先不搞环境搭建了.先通过官网学习了K8S的整体架构,底层原理,又硬啃了一遍K8S源 ...
- Blazor+Dapr+K8s微服务之基于WSL安装K8s集群并部署微服务
前面文章已经演示过,将我们的示例微服务程序DaprTest1部署到k8s上并运行.当时用的k8s是Docker for desktop 自带的k8s,只要在Docker for deskto ...
- Ubuntu22.04 KubeSphere 安装K8S集群
Ubuntu22.04 KubeSphere 安装K8S集群_Ri0n的博客-CSDN博客 一.系统环境系统:Ubuntu 22.04集群IP分布hostname 角色 IP地址master mast ...
- k8s学习笔记之二:使用kubeadm安装k8s集群
一.集群环境信息及安装前准备 部署前操作(集群内所有主机): .关闭防火墙,关闭selinux(生产环境按需关闭或打开) .同步服务器时间,选择公网ntpd服务器或者自建ntpd服务器 .关闭swap ...
- 关于使用rancher部署k8s集群的一些小问题的解决
问题一: 在rancher的ui上,不能创建k8s的master节点的高可用集群.创建k8s集群,添加节点的时候,可以添加多个master,但是多个master又没有高可用,只要其中一个出问题了,那么 ...
随机推荐
- mysql基础_视图
介绍 MySQL 视图(View)是一种虚拟存在的表,同真实表一样,视图也由列和行构成,但视图并不实际存在于数据库中.行和列的数据来自于定义视图的查询中所使用的表,并且还是在使用视图时动态生成的. 优 ...
- flutter填坑之旅(环境搭建篇)
自从Google 在 2018 世界移动大会上发布 Flutter 的 Beta 版本,看看官方的介绍Flutter widgets are built using a modern framewor ...
- WPF入门实例 WPF完整例子 WPF DEMO WPF学习完整例子 WPF实战例子 WPF sql实例应用 WPF资料源码
WPF 和 WinForms 都是用于创建 Windows 桌面应用程序的开发框架,它们有一些相似之处,但也有很多不同之处. 在开发速度方面,这取决于具体情况.如果您熟悉 WinForms 开发并且正 ...
- Godot 4.0 遮罩一个2D物体,使其部分显示
本文针对Godot 4.0. 我也查到了Godot 3.5如何实现遮罩,见这个链接 https://ask.godotengine.org/3031/how-do-i-mask-a-sprite 由于 ...
- C++面试八股文:了解位运算吗?
某日二师兄参加XXX科技公司的C++工程师开发岗位第12面: 面试官:了解位运算吗? 二师兄:了解一些.(我很熟悉) 面试官:请列举以下有哪些位运算? 二师兄:按位与(&).按位或(|).按位 ...
- JetBrain学信网注册(Clion)
一.打开网站 首先打开JetBrains关于学生认证的网站:https://www.jetbrains.com/shop/eform/students,可以看见以下页面: 二.人工验证 人工验证适合于 ...
- CANopen转ProfiNet网关在大跨径门机起重设备同步纠偏控制应用案例
大型门机起重设备纠偏控制系统采用CanOpen通讯协议,而PLC使用的是ProfiNet协议,看似不兼容的两种协议如何实现互通?今天我们来看一下这个案例. 通过捷米特JM-COP-PN设置纠偏系统的参 ...
- Visual Studio C# 多环境配置 Web.config
目录 添加解决方案配置 添加配置转换 添加应对的配置 Visual Studio 为多环境配置 Web.config 不同的环境,存在不同的配置,如:数据库连接字符串,通过多配置,方便做环境切换,配置 ...
- Isito 入门(四):微服务可观测性
本教程已加入 Istio 系列:https://istio.whuanle.cn 目录 可观测性 通过 Gateway 访问 Kiali 查看链路追踪数据 可能失败的原因 修复 Kiali Grafa ...
- 叶绿素含量测定仪SPAD-502怎么使用?
本文介绍基于SPAD-502叶绿素仪测定植被叶片叶绿素含量的方法. SPAD-502是由日本柯尼卡美能达(Konica Minolta)株式会社生产的轻便.手持式叶绿素仪,可以在不破坏作物的情 ...