当前位置: 首页 > news >正文

K8S简介、使用教程

以下是关于 Kubernetes(通常缩写为 K8S)的简介和使用教程:

一、Kubernetes 简介

  1. 定义与作用
    Kubernetes 是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。它最初由谷歌开发,后捐赠给云原生计算基金会(CNCF),并成为云原生领域中非常重要的基础设施。在如今的软件开发和部署场景中,随着容器技术(如 Docker)的广泛应用,Kubernetes 能够帮助开发者和运维团队高效地管理大量的容器,确保应用程序在不同的环境(如开发、测试、生产环境)中可靠且稳定地运行。

  2. 核心概念

    • Pod:是 Kubernetes 中最小的可部署和可管理的计算单元,它可以包含一个或多个紧密相关的容器。这些容器通常会共享网络和存储资源,并且总是一起被调度到同一个节点上运行。例如,一个包含 Web 服务器容器和数据库容器的组合,如果它们之间关联紧密,就可以放在一个 Pod 中(不过实际应用中更建议将数据库单独部署在不同的 Pod 中,这里只是为了便于理解举例)。
    • Node(节点):指的是集群中的一台机器,可以是物理机也可以是虚拟机,节点上运行着 Kubernetes 的相关组件(如 kubeletkube-proxy 等),并且可以用来运行 Pod。简单理解就是承载 Pod 的宿主主机。
    • Service(服务):用于将一组 Pod 暴露给其他应用或者外部网络,提供了稳定的网络访问入口。它可以通过不同的类型(如 ClusterIP 只在集群内部可访问、NodePort 可以通过集群中节点的特定端口访问、LoadBalancer 借助外部负载均衡器来对外提供服务等)实现不同的网络访问需求。
    • Deployment(部署):用于声明式地管理 Pod 的创建、更新和删除等操作,提供了应用程序的滚动更新、回滚等功能,方便开发者对应用进行版本升级等操作。
    • Namespace(命名空间):类似于操作系统中的文件夹,用于对集群中的资源进行隔离和分组管理,不同的命名空间中的资源可以同名,便于在多团队、多项目共用集群时划分资源和权限。

二、Kubernetes 使用教程

安装 Kubernetes
  1. 本地环境安装(以 Minikube 为例,适合用于学习和开发测试)

    • 前提条件:需要先安装好 Docker(因为 Minikube 依赖 Docker 来运行容器)以及对应的命令行工具(如 kubectl,用于与 Kubernetes 集群交互的客户端工具)。
    • 安装步骤
      • 根据操作系统下载对应的 Minikube 安装包(可以从官方网站获取),然后进行安装。
      • 安装完成后,在命令行执行 minikube start 命令来启动本地的 Kubernetes 集群。这个过程中,Minikube 会自动下载所需的镜像等资源并初始化集群。
      • 通过 kubectl get nodes 命令可以查看集群中的节点信息,若看到节点状态为 Ready,则表示集群启动成功。
  2. 生产环境安装(有多种方式,以基于云服务商提供的 Kubernetes 服务为例,如云原生的 Google Kubernetes Engine(GKE)、Amazon Elastic Kubernetes Service(EKS)、阿里云的容器服务 Kubernetes 版等)

    • 以 GKE 为例的步骤
      • 登录 Google Cloud 平台账号,在控制台中选择创建 Kubernetes 引擎集群,按照提示配置集群的相关参数,如节点数量、机器类型、网络配置等。
      • 完成配置后,点击创建,平台会自动完成集群的创建和初始化工作,创建完成后同样可以使用 kubectl get nodes 命令(前提是在本地配置好与 GKE 集群连接的 kubectl)来查看节点信息,确认集群状态。
创建和管理资源
  1. 创建 Pod
    • 使用 YAML 文件定义 Pod(推荐方式,便于版本控制和复用):创建一个例如名为 my-pod.yaml 的文件,内容示例如下:
      apiVersion: v1
      kind: Pod
      metadata:name: my-podlabels:app: my-app
      spec:containers:- name: my-containerimage: nginx:latestports:- containerPort: 80

这个 YAML 文件定义了一个名为 my-pod 的 Pod,它包含一个基于 nginx:latest 镜像的容器,并且容器暴露了 80 端口。

  • 创建 Pod:在命令行执行 kubectl create -f my-pod.yaml 命令,Kubernetes 就会根据这个 YAML 文件创建对应的 Pod。可以通过 kubectl get pods 命令查看 Pod 的状态。
  1. 创建 Deployment
    • 同样使用 YAML 文件定义(例如 my-deployment.yaml
      apiVersion: apps/v1
      kind: Deployment
      metadata:name: my-deploymentlabels:app: my-app
      spec:replicas: 3selector:matchLabels:app: my-apptemplate:metadata:labels:app: my-appspec:containers:- name: my-containerimage: nginx:latestports:- containerPort: 80

这里定义了一个名为 my-deployment 的 Deployment,它会创建 3 个副本(由 replicas 参数指定)的 Pod,Pod 中的容器基于 nginx:latest 镜像且暴露 80 端口。

  • 创建 Deployment:执行 kubectl create -f my-deployment.yaml 命令,通过 kubectl get deployments 和 kubectl get pods 命令可以分别查看 Deployment 和其创建的 Pod 的状态。
  1. 创建 Service
    • 使用 YAML 文件定义服务(例如 my-service.yaml),以下是创建一个 ClusterIP 类型服务的示例
      apiVersion: v1
      kind: Service
      metadata:name: my-servicelabels:app: my-app
      spec:type: ClusterIPselector:app: my-appports:- protocol: TCPport: 80targetPort: 80

这个服务会选择所有带有 app: my-app 标签的 Pod,将它们的 80 端口(targetPort)映射到服务的 80 端口(port)上,并且服务类型为 ClusterIP,意味着只能在集群内部访问。

  • 创建 Service:执行 kubectl create -f my-service.yaml 命令,通过 kubectl get services 命令可以查看服务的相关信息。
应用更新与回滚
  1. 更新 Deployment 中的容器镜像(实现应用版本升级)
    执行 kubectl set image deployment/my-deployment my-container=nginx:new-version 命令(这里假设 nginx:new-version 是要更新的新镜像版本),Kubernetes 会自动进行滚动更新,逐个替换旧版本的 Pod 为新版本的 Pod,在更新过程中可以通过 kubectl rollout status deployment/my-deployment 命令查看更新进度。
  2. 回滚 Deployment
    如果更新后出现问题,可以执行 kubectl rollout undo deployment/my-deployment 命令进行回滚操作,将 Deployment 回滚到上一个版本的状态。
资源删除

要删除之前创建的资源,可以执行以下命令:

  • 删除 Podkubectl delete pod my-pod(不过通常更建议通过管理 Deployment 等上层资源来间接管理 Pod,直接删除 Pod 可能会被重新创建,如果是由 Deployment 管理的话)。
  • 删除 Deploymentkubectl delete deployment my-deployment,这会同时删除它管理的所有 Pod。
  • 删除 Servicekubectl delete service my-service

以上只是 Kubernetes 的一个非常基础的使用教程,实际应用中它还有很多高级的功能和配置选项,比如配置存储卷、网络策略、资源配额等,需要进一步深入学习和实践来掌握。

http://www.lryc.cn/news/492332.html

相关文章:

  • 极狐GitLab 17.6 正式发布几十项与 DevSecOps 相关的功能【四】
  • 麦肯锡报告 | 科技落地的真谛:超越技术本身的价值创造
  • 彻底解决 macOS 下Matplotlib 中文显示乱码问题
  • STM32-- keil 的option for target使用
  • 【MCU】微控制器的编程技术:ISP 与 IAP
  • C#基础题总结
  • Elasticsearch中的节点(比如共20个),其中的10个选了一个master,另外10个选了另一个master,怎么办?
  • 《参与中型项目,领略 Spring 魅力》
  • 计算机网络-GRE(通用路由封装协议)简介
  • 开源电话机器人产品的优点是什么?
  • Spring Boot 集成 Knife4j 的 Swagger 文档
  • 极狐GitLab 17.6 正式发布几十项与 DevSecOps 相关的功能【一】
  • C# 在Word文档模板中,按照占位符插入文字或图片
  • 在使用PCA算法进行数据压缩降维时,如何确定最佳维度是一个关键问题?
  • 深度学习3
  • Qt5.14.2的安装与环境变量及一些依赖库的配置
  • PYNQ 框架 - 时钟系统 + pl_clk 时钟输出不准确问题
  • CDAF / PDAF 原理 | PDAF、CDAF 和 LAAF 对比 | 图像清晰度评价指标
  • 类和对象--中--初始化列表(重要)、隐式类型转化(理解)、最后两个默认成员函数
  • uni-app运行 安卓模拟器 MuMu模拟器
  • java 打印对象所有属性的值 循环
  • k8s认证、授权
  • 基于spring boot的纺织品企业财务管理系统论文
  • @RequestBody和前端的关系以及,如何在前后端之间传递数据?
  • 详解登录MySQL时出现SSL connection error: unknown error number错误
  • 【大数据学习 | Spark-Core】Spark的改变分区的算子
  • Spring Boot Web应用开发:测试
  • 服务器数据恢复—光纤存储FC硬盘数据恢复案例
  • Android Binder技术概览
  • 09 —— Webpack搭建开发环境