Kubernetes 入门指南:快速上手容器编排

本文涉及的产品
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
容器镜像服务 ACR,镜像仓库100个 不限时长
云原生网关 MSE Higress,422元/月
简介: 【8月更文第29天】Kubernetes(简称 K8s)是一个开源平台,用于自动化容器化应用程序的部署、扩展和管理。它提供了一种便捷的方式来部署和运行应用程序,而无需关心底层基础设施的细节。本指南将带你从零开始学习 Kubernetes 的基础知识,并帮助你部署第一个应用。

概述

Kubernetes(简称 K8s)是一个开源平台,用于自动化容器化应用程序的部署、扩展和管理。它提供了一种便捷的方式来部署和运行应用程序,而无需关心底层基础设施的细节。本指南将带你从零开始学习 Kubernetes 的基础知识,并帮助你部署第一个应用。

Kubernetes 基础知识

容器与容器编排

  • 容器:轻量级、可移植的执行环境,包含运行应用程序所需的所有依赖项。
  • 容器编排:自动化的管理容器生命周期的过程,包括部署、扩展、负载均衡等。

Kubernetes 架构

  • Master Node (控制平面): 包含 API Server, Scheduler, Controller Manager 等组件,负责集群状态的管理。
  • Worker Node: 运行 Pod 和容器的实际节点。

Kubernetes 关键概念

  • Pod: Kubernetes 中最小的可部署单元,一个或多个容器的集合。
  • Service: 提供稳定 IP 地址和 DNS 名称的服务,使得 Pod 之间的通信更加简单。
  • Deployment: 用来定义应用的期望状态,Kubernetes 会确保集群中的应用状态与 Deployment 定义的状态一致。
  • Volume: 存储数据的持久化方式,独立于容器生命周期之外。

安装 Kubernetes

本节将指导你如何在本地计算机上安装一个单节点的 Kubernetes 集群,使用 Minikube 工具。Minikube 是一个工具,可以在你的笔记本电脑上运行一个单节点的 Kubernetes 集群。

安装 Minikube

  1. 下载并安装 Minikube:

    • Minikube 官方文档 提供了详细的安装步骤。
    • 对于 macOS 用户,可以通过 Homebrew 安装:
      brew install minikube
      
  2. 启动 Minikube 集群:

    minikube start
    
  3. 验证安装:

    kubectl version
    

部署第一个应用

现在我们已经有了一个运行中的 Kubernetes 集群,接下来我们将部署一个简单的 Nginx Web 服务器。

创建 Nginx Deployment

  1. 编写 Deployment YAML 文件:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: nginx-deployment
    spec:
      replicas: 3
      selector:
        matchLabels:
          app: nginx
      template:
        metadata:
          labels:
            app: nginx
        spec:
          containers:
          - name: nginx
            image: nginx:1.7.9
            ports:
            - containerPort: 80
    
  2. 应用 Deployment:

    kubectl apply -f nginx-deployment.yaml
    
  3. 检查 Deployment 状态:

    kubectl get deployments
    

创建 Service

为了让外部能够访问到我们的 Nginx 应用,我们需要创建一个 Service。

  1. 编写 Service YAML 文件:

    apiVersion: v1
    kind: Service
    metadata:
      name: nginx-service
    spec:
      selector:
        app: nginx
      ports:
        - protocol: TCP
          port: 80
          targetPort: 80
      type: LoadBalancer
    
  2. 应用 Service:

    kubectl apply -f nginx-service.yaml
    
  3. 获取 Service 信息:

    kubectl get services
    
  4. 访问应用:
    如果你正在使用 Minikube,你可以通过以下命令获取 Service 的 URL 并访问它:

    minikube service nginx-service --url
    

总结

通过这篇指南,你应该对 Kubernetes 有了基本的认识,并且已经成功部署了一个简单的 Nginx 应用。这只是 Kubernetes 功能的冰山一角,随着你对它的深入了解,你会发现更多强大的特性和功能。

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
3月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
723 108
|
1月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
1月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
318 2
|
2月前
|
存储 Kubernetes 网络安全
关于阿里云 Kubernetes 容器服务(ACK)添加镜像仓库的快速说明
本文介绍了在中国大陆地区因网络限制无法正常拉取 Docker 镜像的解决方案。作者所在的阿里云 Kubernetes 集群使用的是较旧版本的 containerd(1.2x),且无法直接通过 SSH 修改节点配置,因此采用了一种无需更改 Kubernetes 配置文件的方法。通过为 `docker.io` 添加 containerd 的镜像源,并使用脚本自动修改 containerd 配置文件中的路径错误(将错误的 `cert.d` 改为 `certs.d`),最终实现了通过多个镜像站点拉取镜像。作者还提供了一个可重复运行的脚本,用于动态配置镜像源。虽然该方案能缓解镜像拉取问题,
307 2
|
2月前
|
Kubernetes Devops Docker
Kubernetes 和 Docker Swarm:现代 DevOps 的理想容器编排工具
本指南深入解析 Kubernetes 与 Docker Swarm 两大主流容器编排工具,涵盖安装、架构、网络、监控等核心维度,助您根据团队能力与业务需求精准选型,把握云原生时代的技术主动权。
253 1
|
4月前
|
NoSQL Redis Docker
使用Docker Compose工具进行容器编排的教程
以上就是使用Docker Compose进行容器编排的基础操作。这能帮你更有效地在本地或者在服务器上部署和管理多容器应用。
431 11
|
8月前
|
存储 Kubernetes 监控
K8s集群实战:使用kubeadm和kuboard部署Kubernetes集群
总之,使用kubeadm和kuboard部署K8s集群就像回归童年一样,简单又有趣。不要忘记,技术是为人服务的,用K8s集群操控云端资源,我们不过是想在复杂的世界找寻简单。尽管部署过程可能遇到困难,但朝着简化复杂的目标,我们就能找到意义和乐趣。希望你也能利用这些工具,找到你的乐趣,满足你的需求。
785 33
|
8月前
|
存储 人工智能 Kubernetes
ACK Gateway with AI Extension:面向Kubernetes大模型推理的智能路由实践
本文介绍了如何利用阿里云容器服务ACK推出的ACK Gateway with AI Extension组件,在Kubernetes环境中为大语言模型(LLM)推理服务提供智能路由和负载均衡能力。文章以部署和优化QwQ-32B模型为例,详细展示了从环境准备到性能测试的完整实践过程。

相关产品

  • 容器服务Kubernetes版
  • 推荐镜像

    更多