使用minikube搭建本地k8s练习环境

2024-04-29 02:36

本文主要是介绍使用minikube搭建本地k8s练习环境,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

官网文档; https://minikube.sigs.k8s.io/docs/start/

硬件要求:

  • 2 个或更多 CPU
  • 2GB 可用内存
  • 20GB 可用磁盘空间
  • 容器或虚拟机管理器,例如:Docker、QEMU、Hyperkit、Hyper-V、KVM、Parallels、Podman、VirtualBox或VMware Fusion/Workstation

操作系统: Centos 7.9
使用到的安装包可以从我的网盘下载:链接:https://pan.baidu.com/s/1pOcV53mAguEHInTHTrZXWg
提取码:bhgu

  1. 安装docker

    网上有很多教程可以自行百度,或者直接使用下面的官网安装脚本

     curl -fsSL https://get.docker.com -o get-docker.shsudo sh ./get-docker.sh 
    
    # 修改国内镜像仓库
    mkdir -p /etc/docker
    tee /etc/docker/daemon.json <<-'EOF'
    {"registry-mirrors": ["https://5ym5vu9h.mirror.aliyuncs.com"]
    }
    EOF
    systemctl daemon-reload
    systemctl enable docker --now
    
  2. 安装minikube
    安装方式有很多种,这里我使用适合我发现版本的rpm进行安装

    下载安装包

    在服务器里面无法使用 wget 安装,可以在浏览器里面下载完上传到服务器进行安装。

    https://storage.googleapis.com/minikube/releases/latest/minikube-latest.x86_64.rpm
    

    安装

    rpm -ivh minikube-latest.x86_64.rpm
    
  3. 安装k8s集群

    默认是安装最新的稳定版本,也可以指定版本,如果使用root进行安装,必须使用 --forece,因为默认是以非root身份运行

    # 安装一个1.28版本的k8s
    [root@localhost ~]# minikube start --kubernetes-version=v1.28.0 --force
    * Centos 7.9.2009 上的 minikube v1.33.0
    ! 当提供 --force 参数时,minikube 将跳过各种验证,这可能会导致意外行为
    * 自动选择 docker 驱动。其他选项:none, ssh
    * The "docker" driver should not be used with root privileges. If you wish to continue as root, use --force.
    * 如果您在VM中运行 minikube,请考虑使用 --driver=none:
    *   https://minikube.sigs.k8s.io/docs/reference/drivers/none/X 请求的内存分配(1819MB)小于推荐的最小值 1900MB。部署可能失败。X 请求的内存分配 1819MiB 不足以留出系统开销的空间(总系统内存:1819MiB)。可能会遇到稳定性问题。
    * 建议:Start minikube with less memory allocated: 'minikube start --memory=1819mb'* 使用具有 root 权限的 Docker 驱动程序
    * Starting "minikube" primary control-plane node in "minikube" cluster
    * Pulling base image v0.0.43 ...
    * 正在下载 Kubernetes v1.28.0 的预加载文件...> index.docker.io/kicbase/sta...:  480.29 MiB / 480.29 MiB  100.00% 2.34 Mi> preloaded-images-k8s-v18-v1...:  230.30 MiB / 402.56 MiB  57.21% 1.01 MiB! minikube was unable to download gcr.io/k8s-minikube/kicbase:v0.0.43, but successfully downloaded docker.io/kicbase/stable:v0.0.43 as a fallback image> preloaded-images-k8s-v18-v1...:  402.56 MiB / 402.56 MiB  100.00% 1.03 Mi
    * Creating docker container (CPUs=2, Memory=1819MB) ...
    * 正在 Docker 26.0.1 中准备 Kubernetes v1.28.0- 正在生成证书和密钥...- 正在启动控制平面...- 配置 RBAC 规则 ...
    * 配置 bridge CNI (Container Networking Interface) ...
    * 正在验证 Kubernetes 组件...- 正在使用镜像 gcr.io/k8s-minikube/storage-provisioner:v5
    * 启用插件: default-storageclass, storage-provisioner
    * kubectl 未找到。如果你需要使用它,请尝试:'minikube kubectl -- get pods -A'
    * 完成!kubectl 现在已配置,默认使用"minikube"集群和"default"命名空间
    

    日志:preloaded-images-k8s-v18-v1…: 230.30 MiB / 402.56 MiB 57.21% 1.01 MiB! minikube was unable to download gcr.io/k8s-minikube/kicbase:v0.0.43, but successfully downloaded docker.io/kicbase/stable:v0.0.43 as a fallback image
    可以看出,minikube尝试拉取gcr.io/k8s-minikube/kicbase:v0.0.43,镜像但是没拉下来,就去拉取 docker.io/kicbase/stable:v0.0.43镜像了
    当然你也可以指定国内源,进行下载镜像: minikube start --kubernetes-version=v1.28.0 --image-mirror-country='cn' --force

    # 查看镜像
    [root@localhost ~]# docker images
    REPOSITORY       TAG       IMAGE ID       CREATED      SIZE
    kicbase/stable   v0.0.43   619d67e74933   9 days ago   1.26GB
    
  4. 安装kubectl

    由于我安装的是k8s 1.28的版本,所以kubectl也最好安装一样的版本
    kubectl二进制下载地址: https://dl.k8s.io/release/v1.28.2/bin/linux/amd64/kubectl

    # 安装 kubectl
    install  -m 0755 kubectl /usr/local/bin/kubectl
    
    [root@localhost ~]# kubectl get pod -A
    NAMESPACE     NAME                               READY   STATUS    RESTARTS       AGE
    kube-system   coredns-6554b8b87f-96bq9           1/1     Running   0              143m
    kube-system   etcd-minikube                      1/1     Running   0              144m
    kube-system   kube-apiserver-minikube            1/1     Running   0              144m
    kube-system   kube-controller-manager-minikube   1/1     Running   0              144m
    kube-system   kube-proxy-6g94c                   1/1     Running   0              143m
    kube-system   kube-scheduler-minikube            1/1     Running   0              144m
    kube-system   storage-provisioner                1/1     Running   1 (143m ago)   143m
    
  5. 删除minikube

    minikube stop
    minikube delete
    docker stop $(docker ps -aq)
    rm -r ~/.kube ~/.minikube
    sudo rm /usr/local/bin/localkube /usr/local/bin/minikube
    systemctl stop '*kubelet*.mount'
    sudo rm -rf /etc/kubernetes/
    docker system prune -af –volumes(清理docker没有使用的数据,包括镜像数据,已经停止的容器)
    

这篇关于使用minikube搭建本地k8s练习环境的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/944911

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装