在 Kubernetes 中部署 Web 应用程序

阅读时长 6 分钟读完

背景

Kubernetes 是一种开源的容器编排平台,由 Google 开发并维护。它可以管理容器化应用程序的部署、扩展、管理和自我修复。Kubernetes 已成为云原生技术领域的关键技术之一,越来越多的企业和组织选择使用 Kubernetes 来管理微服务架构。

本文将讲解如何在 Kubernetes 中部署 Web 应用程序。我们将从基础概念开始介绍,并提供一些示例代码来帮助读者理解。

基础概念

在 Kubernetes 中部署 Web 应用程序,需要了解以下基础概念:

Pod

Pod 是 Kubernetes 中最小的可部署单元,一个 Pod 可以包含一个或多个容器。Pod 具有一个独立的 IP 地址和一个唯一的 hostname,并且可以在 Kubernetes 集群中的任何节点上运行。同一个 Pod 内的容器可以共享同一个网络和文件系统。

Deployment

Deployment 用于管理 Pod,它提供了一个声明式的方式来创建和更新 Pod。Deployment 可以指定需要运行的 Pod 的数量,并在容器故障或需要扩展 Pod 数量时自动创建或更新 Pod。

Service

Service 是 Pod 的抽象,它提供了一个稳定的 IP 地址和 hostname,来代表一组 Pod。Service 可以让应用程序无需考虑 Pod 的数量,只需要关注 Service 的 IP 地址和 hostname 即可。

Ingress

Ingress 是 Kubernetes 中的另一个概念,它提供了一种路由机制,将外部流量转发到集群内部的 Service 上。Ingress 可以根据 hostname 或路径将流量路由到不同的 Service 上。

在 Kubernetes 中部署 Web 应用程序,通常需要使用 Deployment,Service 和 Ingress 这三个资源。下面将通过使用一个简单的 Node.js Web 应用程序作为示例,介绍如何在 Kubernetes 中部署 Web 应用程序。

第一步:编写 Dockerfile

在部署 Web 应用程序之前,我们需要编写一个 Dockerfile 来构建 Docker 镜像。下面是一个简单的 Node.js Web 应用程序的 Dockerfile。

-- -------------------- ---- -------
---- ------------

------- ----

---- ------------ -
---- ----------------- -
--- --- -------

---- - -

--- -------- -----------

该 Dockerfile 将基础镜像设置为 node:14-slim,安装 Node.js 应用程序所需的依赖,然后将应用程序复制到容器中,并运行 index.js 应用程序。

第二步:创建 Kubernetes 资源

创建 Kubernetes 资源需要使用 Kubernetes YAML 文件,下面是一个简单的示例。

Deployment YAML 文件

-- -------------------- ---- -------
----------- -------
----- ----------
---------
  ----- -----------------
-----
  --------- -
  ---------
    ------------
      ---- ------
  ---------
    ---------
      -------
        ---- ------
    -----
      -----------
      - ----- ------
        ------ -------------------------
        ------
        - -------------- ----

该 YAML 文件创建了一个名为 webapp-deployment 的 Deployment。Deployment 中运行 3 个 Pod,并且通过 Pod 的标签选择器匹配 app: webapp 标签的 Pod。template 部分定义了 Pod 的模板,其中包括容器,镜像,端口等详细信息。

Service YAML 文件

-- -------------------- ---- -------
----------- --
----- -------
---------
  ----- --------------
-----
  ---------
    ---- ------
  ------
  - ----- ----
    ----- --
    ----------- ----
  ----- ---------

该 YAML 文件创建了一个名为 webapp-service 的 Service。Service 将流量从 80 端口转发到负载均衡策略为 round-robin 的 Pod。Service 运行在 Kubernetes 集群内部,仅可通过集群中的其他 Service 或 Pod 访问。

Ingress YAML 文件

-- -------------------- ---- -------
----------- --------------------
----- -------
---------
  ----- --------------
  ------------
    ------------------------------------------- -
-----
  ------
  - ----- -----------
    -----
      ------
      - ----- -------
        --------- ------
        --------
          --------
            ----- --------------
            -----
              ----- ----

该 YAML 文件创建一个名为 webapp-ingress 的 Ingress。Ingress 将流量从 example.com/webapp 转发到 webapp-service Service。nginx.ingress.kubernetes.io/rewrite-target: / 是为了去掉 URL 的前缀 /webapp。

第三步:部署 Web 应用程序

在安装 Docker 和 Kubernetes CLI 工具后,可以使用以下命令创建 Docker 镜像和部署 Kubernetes 资源。

-- -------------------- ---- -------
- -- ------ --
------ ----- -- ------------------------- -

- - ------ ----------
------ ---- -------------------------

- -- ---------- --
------- ----- -- ---------------
------- ----- -- ------------
------- ----- -- ------------

总结

本文介绍了在 Kubernetes 中部署 Web 应用程序的基本概念,并提供了一个 Node.js Web 应用程序的示例。读者可以根据自己的需求修改代码并进行部署,以实现在 Kubernetes 中部署自己的 Web 应用程序。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/653f221f7d4982a6eb8a90e8

纠错
反馈