跟着GPT学习 Kubernetes ,简称 K8s -- Kind(三)

在 Mac M1 上使用 Kind(Kubernetes in Docker)学习 Kubernetes 是一个非常合适的选择,因为 Kind 可以在本地轻松地创建一个 Kubernetes 集群,适合进行开发、测试和学习。让我们一步一步地从头开始,设置你的环境并逐步学习 Kubernetes。

第一步:安装必备工具

要使用 Kind 学习 Kubernetes,你需要安装以下工具:

  1. Homebrew:macOS 的包管理器,用来安装其他软件。
  2. Docker Desktop:Kind 依赖 Docker 来运行容器。
  3. Kind:用于在 Docker 上运行 Kubernetes。
  4. kubectl:Kubernetes 的命令行工具,用于管理 Kubernetes 集群。
1. 安装 Homebrew

Homebrew 是 macOS 上非常流行的包管理工具,可以方便地安装各种软件包。

  • 打开终端(Terminal),然后执行以下命令来安装 Homebrew:

    /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
    
  • 安装完成后,运行 brew 来检查 Homebrew 是否安装成功:

    brew
    
2. 安装 Docker Desktop

Docker 是一种容器化技术,Kind 需要 Docker 来运行 Kubernetes 节点。

  • 前往 Docker Desktop 下载页面。
  • 下载适用于 Apple Silicon (M1) 的 Docker Desktop 版本。
  • 下载后,打开安装包并按照提示安装 Docker Desktop。
  • 安装完成后,启动 Docker Desktop 并确保 Docker 正常运行。
3. 安装 Kind

Kind 是一个运行在 Docker 容器内的 Kubernetes 集群工具,非常适合本地开发和测试。

  • 使用 Homebrew 安装 Kind:

    brew install kind
    
  • 验证 Kind 是否安装成功:

    kind version
    

    你应该看到类似于 kind vX.Y.Z 的输出。

4. 安装 kubectl

kubectl 是 Kubernetes 的命令行工具,允许你与 Kubernetes 集群进行交互。

  • 使用 Homebrew 安装 kubectl:

    brew install kubectl
    
  • 验证 kubectl 是否安装成功:

    kubectl version --client
    

    你应该看到 kubectl 客户端的版本信息。

第二步:创建一个 Kind Kubernetes 集群

在安装了 Docker 和 Kind 之后,我们可以创建一个本地 Kubernetes 集群。

  1. 创建 Kind 集群

    打开终端,运行以下命令创建一个 Kind 集群。由于 Mac M1 使用的是 ARM 架构,我们需要指定一个 ARM64 兼容的节点镜像:

    kind create cluster --image kindest/node:v1.28.0
    

    kindest/node:v1.28.0 是一个与 M1 芯片(ARM64)兼容的 Kubernetes 节点镜像。如果你想使用其他版本,可以到 Kind 的 Docker Hub 页面查找合适的版本。

  2. 验证集群

    集群创建成功后,运行以下命令验证 Kubernetes 集群是否运行正常:

    kubectl cluster-info --context kind-kind
    

    你应该看到类似于 “Kubernetes control plane is running at …” 的输出,这意味着你的集群已经启动并运行。

第三步:学习 Kubernetes 基本概念

现在你已经在本地运行了一个 Kubernetes 集群,接下来可以学习 Kubernetes 的基础概念和操作。以下是一些关键概念和基本操作:

1. 了解 Kubernetes 基本概念
  • Pod:Kubernetes 中最小的部署单位,通常包含一个或多个容器。
  • Service:一种 Kubernetes 资源,用于暴露运行在一组 Pods 上的服务。
  • Deployment:用于管理无状态应用的 Kubernetes 控制器,负责管理 Pods 的副本集。
  • Namespace:一种虚拟集群,用于将资源分组和隔离。
2. 创建一个简单的 Kubernetes 资源

我们可以使用 kubectl 创建一个简单的 Nginx 应用,并通过 Service 暴露它。

  • 创建一个 Nginx Deployment:

    kubectl create deployment nginx --image=nginx
    

    这会创建一个运行 Nginx 镜像的 Deployment。

  • 查看 Pods 是否已经运行:

    kubectl get pods
    

    你应该看到一个名为 nginx 的 Pod 正在运行。

  • 暴露 Nginx Deployment,使其可以被外部访问:

    kubectl expose deployment nginx --port=80 --type=NodePort
    

    这会创建一个类型为 NodePort 的 Service,将 Nginx 暴露到集群外部。

  • 获取 Service 的详细信息:

    kubectl get services
    

    你会看到 Nginx Service 以及它分配的外部端口(NodePort)。

3. 使用 YAML 文件管理 Kubernetes 资源

Kubernetes 资源通常通过 YAML 文件来定义。让我们来创建一个简单的 YAML 文件来定义 Nginx Deployment。

  • 创建一个名为 nginx-deployment.yaml 的文件,内容如下:

    apiVersion: apps/v1
    kind: Deployment
    metadata:name: nginx-deployment
    spec:replicas: 2selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:containers:- name: nginximage: nginxports:- containerPort: 80
    
  • 使用 kubectl apply 命令应用这个 YAML 文件:

    kubectl apply -f nginx-deployment.yaml
    

    这会创建一个新的 Nginx Deployment,运行两个副本(replicas)。

  • 查看 Deployment 和 Pods:

    kubectl get deployments
    kubectl get pods
    

第四步:探索更多 Kubernetes 特性

随着你对 Kubernetes 的了解逐渐深入,可以进一步学习和实验 Kubernetes 的高级功能和概念:

  • StatefulSet:用于管理有状态应用的控制器。
  • ConfigMap 和 Secret:用于管理配置数据和敏感信息。
  • Ingress:用于管理外部访问集群内部服务的规则。
  • Helm:Kubernetes 的包管理工具,用于安装和管理复杂应用。

第五步:管理和删除 Kind 集群

如果你想删除当前的 Kind 集群,可以使用以下命令:

kind delete cluster

这会删除整个 Kind 集群及其所有资源。

总结

通过以上步骤,你可以在 Mac M1 上成功安装 Kind,并创建一个本地 Kubernetes 集群。接下来,你可以通过阅读官方文档、参加在线课程或实验更多示例来进一步学习 Kubernetes。希望这些信息对你有所帮助!如果你有任何问题或需要进一步的帮助,请随时告诉我。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/51158.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

shallowReactive 与 shallowRef

除了之前的 ref与reactive 之外,Vue3 还准备了另外两个API,也是用来对响应式数据做处理,那就是 shallowReactive 与 shallowRef shallowReactive 文档解释:reactive() 的浅层作用形式,只能定义对象类型的数据。和 r…

Spring Boot整合Sentry

Spring Boot整合Sentry Sentry搭建Sentry中新建项目集成SpringBoot1. 添加依赖2. 配置Sentry4. 日志集成(可选)5. 测试Sentry集成6. 配置实时告警配置Alert Settings配置警报规则 发送消息服务代码参照文档 Sentry 是一个日志平台,分为客户端…

AI 未来两年:史无前例的变革与挑战

2024 年 8 月 20 日,正站在科技变革的风暴中心,见证着人工智能(AI)以惊人的速度重塑着世界。谷歌前 CEO Eric Schmidt 对 AI 未来两年的预测,引起了广泛关注,如今 YC 的 CEO Garry Tan 也高度赞同这些观点&…

CMakeLists.txt模板

#设置编译该CMakeLists.txt文件所需要的最低cmake版本 CMAKE_MINIMUM_REQUIRED(VERSION 最低版本号)# 该项目名称 PROJECT(项目名称)SET(CMAKE_CXX_STANDARD 11)SET(CMAKE_C_STANDARD 11)# 此行可以理解为将路径下所有的文件装载到自定义集合filelist中 FILE(GLOB filelist &q…

Vite + Vue 3 项目中实现路由自动化完整步骤。

下面是从创建项目到实现路由自动化的完整步骤 在 Vite Vue 3 项目中实现路由自动化可以通过使用文件系统路由生成器来简化路由管理过程。以下是实现路由自动化的完整步骤: 1.创建 Vite Vue 3 项目 如果你还没有一个 Vite Vue 3 项目,可以使用以下命令…

利用MongoDB进行数据治理,防范构建生成式AI应用程序时的潜在安全风险

生成式人工智能(生成式AI)正在蓬勃发展,许多企业和初创公司正在运用AI工具来解决各自的用例问题。随着企业逐渐适应市场上的新技术范式转移,开发者社区和开源模型也在不断发展壮大。 构建智能生成式AI应用程序需要灵活运用数据。…

基础算法--高精度数据(1)

高精度数据处理一般内容简单,写代码难度较大,可能部分内容涉及基础数学、初等数论等知识。请小心食用。不过本节不会给大家太难的高精度处理,我们第一次接触,不能劝退大家对吧。 高精度算法是指,利用基础或高级的数学…

盘古信息IMS MCM制造协同管理系统:为中小企业数字化转型量身打造的数字化方案

近年来,全球经济的不稳定性,给中小企业的经营和发展带来了巨大的挑战。为提升企业竞争力,中小企业纷纷谋求数字化转型路径,优化生产流程、提高运营效率、降低生产成本,以应对变幻莫测的市场环境。IMS MCM是盘古信息为广…

进阶-4.视图、存储过程、存储函数、触发器

视图、存储过程、存储函数、触发器 1.视图1.1 介绍1.2 语法1.3 视图的检查选项1.4 视图的更新1.5 视图作用1.6 案例 2.存储过程21. 介绍2.2 特点2.3 语法2.4 变量2.4.1 系统变量2.4.2用户自定义变量2.4.3 局部变量 2.5参数2.6条件语句2.6.1 if 语法2.6.2 case 2.7循环结构2.7.1…

【数据库和数据仓库】

数据仓库和数据库主要有以下区别: 一、用途不同 数据库:就像一个日常的储物间,主要用于存储和管理日常业务操作中的各种数据,比如电商网站中用户的下单信息、银行系统中客户的交易记录等。它的目的是支持业务的实时交易处理&…

通过IDEA创建spring boot的web项目

1.Fle->New->Project,选择Maven&#xff0c;点击Next 2.修改项目名称&#xff0c;点击Finish 3.项目创建完毕&#xff0c;等待Maven下载完成 4.修改pom.xml文件&#xff0c;改成如下内容 <?xml version"1.0" encoding"UTF-8"?> <pr…

增强管道数据流转(EPDR)技术的设计局限和替代

在前文中&#xff0c;我们介绍了EPDR技术的起源&#xff0c;以及使用该技术驱动的业余软件无线电平台专栏。已有玩家通过踩坑证明&#xff0c;进程管道交换数据时间延迟大&#xff0c;构造时间敏感系统难。除非采用传统的紧耦合设计及更大的颗粒度&#xff0c;否则很难在期望的…

Openstack 与 Ceph集群搭建(中): Ceph部署

文章目录 一、部署前说明1. ceph 版本选择依据2. ceph网络要求3. 硬件要求 二、部署架构三、部署过程1. 通用步骤2. 部署管理节点创建账号安装Cephadm运行bootstrap 3. 登录Ceph web4. 将其他节点加入集群同步ceph key安装ceph CLI命令行添加主机节点到集群添加OSD节点将监控节…

【Canvas与艺术】环形橄榄枝纹饰

【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>环形橄榄枝(draft2)</title><style type"text/css&quo…

安卓蓝牙日志的获取方法

有过蓝牙调试经历的同学们可能都知道&#xff0c;在安卓系统中&#xff0c;在手机的设置–>开发人员页面下有一个开启蓝牙HCI信息收集日志选项开关&#xff0c;如下图中标红处&#xff0c; 打开该开关&#xff0c;就可以收集本机发送和接收的蓝牙HCI包。蓝牙包的数据会保存在…

git提交本地项目到远程仓库

1、查看项目目录&#xff0c;是否存在.git文件夹&#xff08;若存在则删除&#xff09; 2、登录git并新建一个空白项目 3、idea创建本地git仓库&#xff08;选择本地项目&#xff09; 4、添加要提交的项目&#xff08;项目右键&#xff09; 5、提交代码到本地仓库 6、配置远程…

轻松实现微服务间的无缝通信:OpenFeign入门指南

OpenFeign 前言1、导入依赖2、开启feign调用3、编写OpenFeign客户端4、Fegin接口实现5、Feign接口调用 前言 Spring Cloud OpenFeign是一种基于Spring Cloud的声明式REST客户端&#xff0c;它简化了与HTTP服务交互的过程。它将REST客户端的定义转化为Java接口&#xff0c;并且…

css 宫格样式内容上下结构

结构 <div class"sc-content-group"><div class"sc-content-item"><div class"sc-item-img"><el-image :src"src" :preview-src-list"[src]"></el-image></div><div class"s…

datax关于postsql数据增量迁移的问题

看官方文档是不支持的 数据源及同步方案_大数据开发治理平台 DataWorks(DataWorks)-阿里云帮助中心 (aliyun.com) 看了下源码有个postsqlwriter 看了下也就拼接sql 将 PostgresqlWriter中的不允许更新先注释了 让他过去先 然后看到 WriterUtil中的对应方法 getWriteTemplat…

linux 网卡配置

linux网卡可以通过命令和配置文件配置,如果是桌面环境还可以通过图形化界面配置. 1.ifconfig(interfaces config)命令方式 通常需要以root身份登录或使用sudo以便在Linux机器上使用ifconfig工具。依赖于ifconfig命令中使用一些选项属性&#xff0c;ifconfig工具不仅可以被用来…