如何在本地快速启动一个k8s集群?小技巧,学到了

2023-11-16

背景

最近在阅读《每天5分钟玩转Kubernetes》 这本书,个人感觉是一本不错的 K8S 的入门书籍。

我们在刚开始学习一项技术的时候,不论是通过官方文档、书籍,亦或是视频的形式,如果仅仅是去看,而不去练习实践的话,那么是很难将其真正应用起来的。

然而当我开始准备实践的时候,发现要想在本地将 K8S 跑起来,并不像我们想象的那么容易。存在以下几点「问题」:

网络环境:K8S 里面的一些镜像在国内很难将其 pull 下来,当然这可以通过代理、镜像站等方式解决。

资源消耗:在内存资源不这么充裕的本地开发环境,去部署一个 K8S 集群,这无疑不是一个明智的选择。

那么有没有什么方案可以更优雅更轻量更快速搭建一个 K8S 集群呢?答案就是 k3d。

其实有很多种方式可以在本地运行 k8s,比如:

minikube 仅支持单节点,但是我们期望可以跑一个集群的方式,方便我们去 Mock 节点宕机之后 K8S 自动调度的 case ✖️

microk8s 是 Ubuntu 生态里提供的一个可以单机运行的 k8s 版本,配合 Ubuntu 生态的 multipass,可以模拟多节点,但是在本就资源紧张的本地环境,通过虚拟机的方式模拟多节点,显然并不是我想要的 ✖️

kind 是一个基于 docker 构建 Kubernetes 集群的工具,Kubernetes in Docker ✔️

k3d 是一个可以让 k3s 运行在 Docker 中的工具,相比于 kind ,启动速度更快,占用资源更小,也是我采取的一种方案 ✅

当然了,如果只是学习 k8s 的使用,那么以上方案均可以使用。

关于 k3d 以及 kind 的对比,可以参考 K3d vs Kind 谁更适合本地研发。

1. 什么是 k3d + k3s ?

k3s 是一种非常快速且轻量级的完全兼容的 Kubernetes 发行版(CNCF 认证)。
k3d 是一个可以让 k3s 运行在 Docker 中的工具,它提供了一个简单的 CLI 来创建、运行和删除具有 1 到 N 个节点的 Kubernetes 集群。

k3s 包括以下一些组件:

Containerd:一个类似 Docker 的运行时容器,但是它不支持构建镜像

Flannel:基于 CNI 实现的网络模型,默认使用的是 Flannel,也可以使用 Calico 等其他实现替换

CoreDNS:集群内部 DNS 组件

SQLite3:默认使用 SQLite3 进行存储,同样也支持 etcd3, MySQL, Postgres

Traefik:默认安装 Ingress controller 是 traefik 1.x 的版本

Embedded service loadbalancer:内嵌的一个服务负载均衡组件

k3s 是一种模块化的发行版,可以很方便的替换上面的组件。

2. 安装 k3d

在 Mac 下,使用 Homebrew 可以很方便的安装 k3d: brew install k3d。

顺手安装一下 kubectl 和 kubecm:

brewinstall kubectlbrewinstall kubecm

3. 小试牛刀

我们通过 k3d 的命令可以轻易的在本地启动一个或 N 个 k8s 集群。

首先我们尝试创建一个 1主2从 的集群:

k3dclustercreatefirst-cluster--port8080:80@loadbalancer--port8443:443@loadbalancer--api-port6443--servers1--agents2

初次创建可能会比较慢,因为会从 Docker 仓库拉取最新的 rancher/k3s 镜像。

当出现下面的日志时,k8s 集群就创建成功了

INFO[0000] Prep: Network
INFO[0000] Created network 'k3d-first-cluster'
INFO[0000] Created volume 'k3d-first-cluster-images'
INFO[0001] Creating node 'k3d-first-cluster-server-0'
INFO[0001] Creating node 'k3d-first-cluster-agent-0'
INFO[0001] Creating node 'k3d-first-cluster-agent-1'
INFO[0001] Creating LoadBalancer 'k3d-first-cluster-serverlb'
INFO[0001] Starting cluster 'first-cluster'
INFO[0001] Starting servers...
INFO[0001] Starting Node 'k3d-first-cluster-server-0'
INFO[0008] Starting agents...
INFO[0008] Starting Node 'k3d-first-cluster-agent-0'
INFO[0020] Starting Node 'k3d-first-cluster-agent-1'
INFO[0028] Starting helpers...
INFO[0028] Starting Node 'k3d-first-cluster-serverlb'
INFO[0029] (Optional) Trying to get IP of the docker host and inject it into the cluster as'host.k3d.internal'for easy access
INFO[0031] Successfully added host record to /etc/hosts in4/4 nodes and to the CoreDNS ConfigMap
INFO[0031] Cluster 'first-cluster' created successfully!
INFO[0031] --kubeconfig-update-default=false --> sets --kubeconfig-switch-context=false
INFO[0031] You can now use it like this:
kubectl config use-context k3d-first-cluster
kubectl cluster-info

此时,我们按照日志提示,运行 kubectl cluster-info 查看下当前集群的信息:

Kubernetes master is running at https://0.0.0.0:6443
CoreDNS is running at https://0.0.0.0:6443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
Metrics-server is running at https://0.0.0.0:6443/api/v1/namespaces/kube-system/services/https:metrics-server:/proxy

运行 kubectl get nodes 查看下当前集群的节点情况:

NAMESTATUSROLESAGEVERSIONk3d-first-cluster-agent-1Ready    <none>                 178mv1.20.2+k3s1k3d-first-cluster-server-0Readycontrol-plane,master   178mv1.20.2+k3s1k3d-first-cluster-agent-0Ready    <none>                 178mv1.20.2+k3s1

注意,这里的“节点”其实是本机 Docker 运行的容器,通过 docker ps 查看下当前本机运行的容器吧

CONTAINERIDIMAGECOMMANDCREATEDSTATUSPORTSNAMESa757151daf14rancher/k3d-proxy:v4.2.0"/bin/sh -c nginx-pr…"4hoursagoUp4hours0.0.0.0:6443->6443/tcp,0.0.0.0:8080->80/tcp,0.0.0.0:8443->443/tcpk3d-first-cluster-serverlb6fcb1bbaf96erancher/k3s:latest"/bin/k3s agent"4hoursagoUp4hoursk3d-first-cluster-agent-1cef7277e43b9rancher/k3s:latest"/bin/k3s agent"4hoursagoUp4hoursk3d-first-cluster-agent-05d438c1b5087rancher/k3s:latest"/bin/k3s server --t…"4hoursagoUp4hoursk3d-first-cluster-server-0

解释一下我们创建集群时配置的端口映射:

--port 8080:80@loadbalancer 会将本地的 8080 端口映射到 loadbalancer 的 80 端口,然后 loadbalancer 接收到 80 端口的请求后,会代理到所有的 k8s 节点。

--api-port 6443 默认提供的端口号,k3s 的 api-server 会监听 6443 端口,主要是用来操作 Kubernetes API 的,即使创建多个 Master 节点,也只需要暴露一个 6443 端口,loadbalancer 会将请求代理分发给多个 Master 节点。

如果我们期望通过 NodePort 的形式暴露服务,也可以自定义一些端口号映射到 loadbalancer 来暴露 k8s 的服务,比如:-p 10080-20080:10080-20080@loadbalancer

现在我们集群和主机的网络通信是这样子的:

4. 测试

创建一个 nginx 的 Deployment

kubectl create deployment nginx --image=nginx

创建一个 Service 通过 ClusterIP 的方式暴露服务

kubectl create service clusterip nginx --tcp=80:80

创建一个 Ingress,k3s 默认安装的是 traefik 1.x 作为 Ingress Controller

cat<<EOF|kubectlapply-f-apiVersion:networking.k8s.io/v1kind:Ingressmetadata:name:nginxannotations:ingress.kubernetes.io/ssl-redirect:"false"spec:rules:-http:paths:-path:/pathType:Prefixbackend:service:name:nginxport:number:80EOF

此时,打开浏览器,访问 http://localhost:8080/ 就可以看到熟悉的 nginx 默认页。

这是不是太酷了~

5. 其它

5.1. 管理集群

停止集群:k3d cluster stop first-cluster

重启集群:k3d cluster start first-cluster

删除集群:k3d cluster delete first-cluster

5.2. 创建指定版本的k8s集群

当使用 Helm Chart 安装 Rancher 时,可能会出现如下错误日志:

chartrequireskubeVersion: < 1.20.0-0whichisincompatiblewithKubernetesv1.20.0+k3s2
测试时 Rancher 版本号为 2.5.5,目前最新的 2.5.6 已经可以支持 1.20.x 版本了

要创建一个 k8s 版本号为 v1.19.8-k3s1 的 k8s 集群,可以在创建集群的命令后面加 --image 参数,指定版本号:k3d cluster create first-cluster xxxxx --image rancher/k3s:v1.19.8-k3s1

5.3. 快速切换 kubectl context

还记得在第二步顺手安装的 kubecm 吗?

当我们在本地使用 k3d 创建了多个集群之后,我们可以通过 kubecm 快速切换 context。

$ kubecm s
Use the arrow keysto navigate: ↓ ↑ → ←  and / toggles searchSelect Kube Context
   k3d-first-cluster(*)
    k3d-dev
    k3d-rancher-test
    <Exit>

--------- Info ----------Name:           k3d-first-cluster
Cluster:        k3d-first-cluster
User:           admin@k3d-first-cluster

参考

k3s:k3s.io/

k3d:k3d.io/

kubecm:github.com/sunny0826/k

资源获取:
大家 点赞、收藏、关注、评论啦 、 查看
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在本地快速启动一个k8s集群?小技巧,学到了 的相关文章

随机推荐

  • FPGA UART仿真

    摘自威三学员尤凯元 tb文件 Copyright c 2014 2019 All rights reserved Author Youkaiyuan v3eduyky 126 com wechat 15921999232 File tb t
  • 微信支付sign签名工具类

    secretKey为商户平台设置的密钥key params为非空参数集合 public static String genSignature String secretKey Map
  • ubuntu从内核源代码编译内核及替换内核

    1 下载ubuntu对应的linux内核源代码 apt catch search linux source 查看当前linux内核版本 apt get install linux source lt 对应的内核版本好 gt 下载对应的lin
  • 不列颠哥伦比亚大学推出面向硕士生和博士生的区块链项目

    点击上方 蓝色字 可关注我们 暴走时评 加拿大领先的研究型大学之一 不列颠哥伦比亚大学 UBC 正在为研究生推出获得区块链技术教育的途径 该项目计划专注于四个领域 健康与保健 清洁能源 监管技术和土着居民问题 并将于明年1月正式启动 作者
  • 解决PytestUnknownMarkWarning: Unknown pytest.mark.pre - is this a typo?

    问题描述 在pytest框架中 执行标记的用例时 出现了如下提示 PytestUnknownMarkWarning Unknown pytest mark pre is this a typo 这个提示的大致意思是pytest找不到标记 发
  • &1的用法

    看到不少大神都喜欢用 1来判断一些东西 但是作为渣渣的我总是不理解这个 1到底是有什么作用 今天写了程序看了一下 其实是判断奇偶用的 如果是奇数 其结果为1 偶数结果为false 我在这里想吐槽一下 大神为什么不直接mod2判断呢 incl
  • NO.18 什么是拜占庭将军问题

    本文是转载 转载自苏神的博客 原文地址 https www jianshu com p 5fea30b25f0a 拜占庭将军问题很多人可能听过 但不知道是什么意思 本文从非专业的角度来讲讲 拜占庭将军问题到底是说什么的 拜占庭将军问题 By
  • Vue全局自定义指令 和 局部自定义指令

    文章目录 自定义指令 Vue全局自定义指令 Vue局部自定义指令 Vue钩子函数 Vue钩子函数传参数详解 钩子函数简写或者合并 自定义指令 除了Vue核心的内置指令 例如 v model 和 v show等 以外 Vue也允许自己定义指令
  • Parsing error Unexpected token错误解决方案

    问题描述 import动态导入 将js文件单独打包时 webpack打包错误 import test then res gt 文件加载成功 console log res mul 2 5 catch gt console log 文件加载失
  • android native 使用opengl es画点线面图形(纯c++)

    一 首先需要对EGL进行初始化 void Renderer initEGL const EGLint attribs EGL SURFACE TYPE EGL WINDOW BIT EGL BLUE SIZE 8 EGL GREEN SIZ
  • Deprecated: __autoload() is deprecated, use spl_autoload_register()

    官网是这样说的 spl autoload register PHP 5 gt 5 1 0 PHP 7 spl autoload register 注册给定的函数作为 autoload 的实现 说明 spl autoload register
  • ply补全为立方体_PLY 文件结构

    典型的 PLY 文件结构 头部 顶点列表 面片列表 其他元素列表 头部是一系列以回车结尾的文本行 用来描述文件的剩余部分 头部包含一个对每个元素类型的描述 包括元素名 如 边 这个元素在工程里有多少 以及一个与这个元素关联的不同属性的列表
  • 第八章 假设检验

    目录 一 假设检验的基本概念 假设及假设检验的定义 原假设与备择假设 基本思想 接受域与拒绝域 假设检验的分类 两类错误 二 一个正态总体下的参数假设检验 期望 方差的假设检验 三 两个正态总体下的参数假设检验 期望的差异性 方差的差异性的
  • 【H5】 svg的 defs用法 渐变

    defs defs元素用于预定义一个元素使其能够在SVG图像中重复使用 在元素中定义的图形不会直接显示在SVG图像上 要显 示它们需要使用元素来引入它们 symbol 元素用于定义可重复使用的符号 嵌入在元素中的图形是不会被直接显示 的 除
  • 前端高频面试题汇总(css,html)

    目录 H5 的新特性有哪些 C3 的新特性有哪些 如何使一个盒子水平垂直居中 如何实现双飞翼 圣杯 布局 CSS 的盒模型 CSS 中选择器的优先级以及 CSS 权重如何计算 列举 5 个以上的 H5 input 元素 type 属性值 C
  • Keil警告warning: #223-D: function “memcpy” declared implicitly

    使用memcpy 函数编译后出现警告 解决方案 在 h文件中加上头文件 include string h
  • GPTzero

    关于GPTzero 网址 https gptzero me 这是我今天才发现的网站 功能是你可以分辨任何人工智能写的文章与人为写的文章 注册方法 注册方法非常简单 只需要一个电子邮箱 我用的是outlook邮箱 其他的也行 使用方法 登录成
  • 【超分辨率】—基于深度学习的图像超分辨率最新进展与趋势

    1 简介 图像超分辨率是计算机视觉和图像处理领域一个非常重要的研究问题 在医疗图像分析 生物特征识别 视频监控与安全等实际场景中有着广泛的应用 随着深度学习技术的发展 基于深度学习的图像超分方法在多个测试任务上 取得了目前最优的性能和效果
  • 我在修改jupyter字体的时候输入命令jt -l 遇到了jt既不是内部也不是外部命令咋整?...

    点击上方 Python爬虫与数据挖掘 进行关注 回复 书籍 即可获赠Python从入门到进阶共10本电子书 今 日 鸡 汤 独立三边静 轻生一剑知 大家好 我是Python进阶者 一 前言 前几天在Python白银交流群 Joker 问了一
  • 如何在本地快速启动一个k8s集群?小技巧,学到了

    背景 最近在阅读 每天5分钟玩转Kubernetes 这本书 个人感觉是一本不错的 K8S 的入门书籍 我们在刚开始学习一项技术的时候 不论是通过官方文档 书籍 亦或是视频的形式 如果仅仅是去看 而不去练习实践的话 那么是很难将其真正应用起
Powered by Hwhale