如何在 Kubernetes 中创建具有一个副本的 Nginx 部署

KubernetesKubernetesBeginner
立即练习

💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版

简介

本教程将指导你了解 Kubernetes 的基础知识,在 Kubernetes 集群上部署一个具有一个副本的 Nginx 应用程序,并监控该部署。在本教程结束时,你将对 Kubernetes 有扎实的理解,并能够在 Kubernetes 集群上部署自己的容器化应用程序。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL kubernetes(("Kubernetes")) -.-> kubernetes/TroubleshootingandDebuggingCommandsGroup(["Troubleshooting and Debugging Commands"]) kubernetes(("Kubernetes")) -.-> kubernetes/BasicCommandsGroup(["Basic Commands"]) kubernetes(("Kubernetes")) -.-> kubernetes/AdvancedCommandsGroup(["Advanced Commands"]) kubernetes/BasicCommandsGroup -.-> kubernetes/get("Get") kubernetes/BasicCommandsGroup -.-> kubernetes/create("Create") kubernetes/BasicCommandsGroup -.-> kubernetes/run("Run") kubernetes/AdvancedCommandsGroup -.-> kubernetes/apply("Apply") kubernetes/TroubleshootingandDebuggingCommandsGroup -.-> kubernetes/describe("Describe") subgraph Lab Skills kubernetes/get -.-> lab-417504{{"如何在 Kubernetes 中创建具有一个副本的 Nginx 部署"}} kubernetes/create -.-> lab-417504{{"如何在 Kubernetes 中创建具有一个副本的 Nginx 部署"}} kubernetes/run -.-> lab-417504{{"如何在 Kubernetes 中创建具有一个副本的 Nginx 部署"}} kubernetes/apply -.-> lab-417504{{"如何在 Kubernetes 中创建具有一个副本的 Nginx 部署"}} kubernetes/describe -.-> lab-417504{{"如何在 Kubernetes 中创建具有一个副本的 Nginx 部署"}} end

理解 Kubernetes 基础知识

Kubernetes 是一个强大的开源容器编排平台,已成为管理和部署容器化应用程序的事实上的标准。它为跨多个主机自动部署、扩展和管理容器化应用程序提供了一个强大且可扩展的解决方案。

Kubernetes 架构

Kubernetes 采用主从架构,其中主节点负责管理整个集群,而工作节点负责运行容器化应用程序。Kubernetes 架构的关键组件包括:

graph TD A[主节点] --> B[API 服务器] A --> C[控制器管理器] A --> D[调度器] A --> E[etcd] B --> F[工作节点] F --> G[Kubelet] F --> H[容器运行时] F --> I[Pod]
  1. API 服务器:Kubernetes 集群内的通信中心点,负责处理所有 API 请求并管理集群状态。
  2. 控制器管理器:负责维护集群的期望状态,例如确保运行正确数量的副本并管理其他资源。
  3. 调度器:负责根据资源可用性和其他约束条件将新的 Pod 放置到合适的工作节点上。
  4. etcd:一个分布式键值存储,用于存储集群的配置和状态。
  5. Kubelet:在每个工作节点上运行的代理,负责管理 Pod 的生命周期并向主节点报告节点状态。
  6. 容器运行时:负责在工作节点上运行和管理容器的软件,例如 Docker 或 containerd。
  7. Pod:Kubernetes 中的基本部署单元,可以包含一个或多个容器。

Kubernetes 组件

Kubernetes 提供了丰富的组件和资源,用于实现容器化应用程序的部署和管理。一些关键组件包括:

组件 描述
Pod Kubernetes 中最小的可部署单元,代表一个或多个容器。
部署 管理无状态应用程序生命周期的声明式方式。
服务 为访问集群内的应用程序提供稳定的网络端点。
为容器提供持久存储,允许数据共享和持久化。
ConfigMap 提供一种将配置数据与应用程序代码分开存储和管理的方式。
密钥 安全地存储敏感信息,例如密码、API 密钥或证书。

Kubernetes 的用例

Kubernetes 在各个行业和用例中都得到了广泛应用,包括:

  1. 微服务和容器化应用程序:Kubernetes 在管理和编排容器化应用程序方面表现出色,使其成为基于微服务架构的理想选择。
  2. 可扩展和高可用应用程序:Kubernetes 提供自动扩展、负载均衡和自我修复功能,确保应用程序能够处理增加的流量并保持高可用性。
  3. 混合云和多云部署:Kubernetes 对底层基础设施的可移植性和抽象性使其成为在不同云提供商或本地环境中部署应用程序的合适选择。
  4. 批处理和数据管道:Kubernetes 可用于编排和管理批处理作业、数据管道和其他有状态工作负载。

通过理解 Kubernetes 的基础知识,开发人员和运维团队可以利用其强大功能来构建、部署和管理可扩展、弹性和高可用的应用程序。

在 Kubernetes 上部署 Nginx 应用程序

在本节中,我们将探讨在 Kubernetes 集群上部署 Nginx 网络服务器应用程序的过程。Nginx 是一个广受欢迎的开源网络服务器,可以轻松地进行容器化并部署在 Kubernetes 上。

Nginx 部署清单

要在 Kubernetes 上部署 Nginx,我们需要创建一个部署清单。以下是一个 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:latest
          ports:
            - containerPort: 80

此部署清单将创建 Nginx 容器的三个副本,每个副本都监听端口 80。

部署 Nginx 应用程序

要部署 Nginx 应用程序,你可以使用 kubectl 命令行工具:

kubectl apply -f nginx-deployment.yaml

此命令将在你的 Kubernetes 集群中创建 Nginx 部署。

访问 Nginx 应用程序

要访问 Nginx 应用程序,你需要创建一个 Kubernetes 服务。以下是一个服务清单示例:

apiVersion: v1
kind: Service
metadata:
  name: nginx-service
spec:
  type: LoadBalancer
  ports:
    - port: 80
      targetPort: 80
  selector:
    app: nginx

此服务清单使用负载均衡器服务类型公开 Nginx 部署,这将创建一个用于访问应用程序的公共 IP 地址。

你可以使用以下命令应用服务清单:

kubectl apply -f nginx-service.yaml

服务创建完成后,你可以使用分配给负载均衡器服务的外部 IP 地址访问 Nginx 应用程序。

通过在 Kubernetes 上部署 Nginx,你可以利用 Kubernetes 的功能,如自动扩展、自我修复和负载均衡,来确保你的 Web 应用程序的可靠性和可扩展性。

监控和管理 Kubernetes 部署

Kubernetes 提供了丰富的工具和功能,用于监控和管理已部署应用程序的健康状况和性能。在本节中,我们将探讨监控和管理 Kubernetes 部署的一些关键方面。

Kubernetes 健康检查

Kubernetes 为你的容器支持两种类型的健康检查:

  1. 存活探针:检查容器是否仍在运行并响应。如果存活检查失败,Kubernetes 将自动重启容器。
  2. 就绪探针:检查容器是否准备好接受流量。如果就绪检查失败,Kubernetes 将不会将流量路由到该容器。

以下是一个就绪探针配置示例:

readinessProbe:
  httpGet:
    path: /healthz
    port: 8080
  periodSeconds: 5
  failureThreshold: 3

此配置每 5 秒检查一次端口 8080 上的 /healthz 端点,如果在 3 次尝试中至少成功一次,则认为容器已就绪。

监控 Kubernetes 资源

Kubernetes 提供了内置指标,你可以使用这些指标来监控集群和应用程序的健康状况和性能。你可以使用 Prometheus、Grafana 或 Kubernetes 仪表板等工具来可视化和分析这些指标。

一些要监控的关键指标包括:

  • Pod 指标:CPU 和内存使用情况、重启次数以及其他 Pod 级指标。
  • 节点指标:工作节点的 CPU、内存和磁盘利用率。
  • 部署指标:副本数、可用和不可用副本。
  • 服务指标:传入和传出流量、延迟和错误率。

扩展 Kubernetes 部署

Kubernetes 提供了自动扩展功能,以确保你的应用程序能够处理增加的流量和负载。你可以配置水平 Pod 自动缩放(HPA),以根据 CPU 或内存利用率自动缩放副本数量。

以下是一个 HPA 配置示例:

apiVersion: autoscaling/v2beta1
kind: HorizontalPodAutoscaler
metadata:
  name: nginx-hpa
spec:
  scaleTargetRef:
    apiVersion: apps/v1
    kind: Deployment
    name: nginx-deployment
  minReplicas: 3
  maxReplicas: 10
  metrics:
    - type: Resource
      resource:
        name: cpu
        targetAverageUtilization: 50

此 HPA 配置将根据 Pod 的平均 CPU 利用率在 3 到 10 个副本之间自动缩放 Nginx 部署。

通过利用 Kubernetes 的监控和管理功能,你可以确保已部署应用程序的可靠性、可扩展性和性能。

总结

在本教程中,你已经了解了 Kubernetes 架构的关键组件,包括 API 服务器、控制器管理器、调度器、etcd、Kubelet 和容器运行时。你还在 Kubernetes 集群上部署了一个具有一个副本的 Nginx 应用程序,并学习了如何监控该部署。有了这些知识,你现在可以自信地在 Kubernetes 平台上部署和管理自己的容器化应用程序了。