Kubernetes 是当今最流行的容器编排工具之一,为部署容器化应用程序提供了强大的支持。在 Kubernetes 中,无状态应用是一种不需要存储持久数据的应用,例如 Web 服务器、负载均衡器、API 网关等等。在本文中,我们将介绍如何在 Kubernetes 集群上运行无状态应用程序。
前置条件
在开始之前,您需要具备以下知识:
- Docker 容器基础知识
- Kubernetes 资源和对象的概念
- YAML 文件的基础知识
步骤
- 创建一个无状态应用的 Docker 镜像
首先,我们需要创建一个可用于 Kubernetes 中的 Docker 镜像。该镜像将包含您的应用程序和所需的依赖项。例如,以下 Dockerfile 文件将创建一个 Node.js 应用程序的 Docker 镜像:
---- -------------- ------- ---- ---- ------------- -- --- --- ------- ---- - - ------ ---- --- ------- --------
在 Dockerfile 目录下使用以下命令来构建 Docker 镜像:
------ ----- -- -------- -
- 创建一个 Kubernetes 部署对象
接下来,我们将创建一个名为 myapp 的 Kubernetes 部署对象,并将 myapp:v1 镜像部署到其内部。以下是这个部署对象的 YAML 简介:
----------- ------- ----- ---------- --------- ----- ----- ----- --------- - --------- ------------ ---- ----- --------- --------- ------- ---- ----- ----- ----------- - ----- ----- ------ -------- ------ - -------------- ----
在 Kubernetes 中,Deployment 是一个创建和管理 Pod 的资源对象。在 YAML 简介中,我们指定了应用实例的数量(replicas)、Pod 的选择器以及 Pod 模板,其中包含 myapp 容器的定义。
将上面的 YAML 保存为 myapp-deployment.yaml,并使用以下命令在集群上创建这个部署对象:
------- ----- -- ---------------------
该命令将根据 YAML 文件在 Kubernetes 上部署您的应用程序。
- 创建一个 Kubernetes 服务对象
我们已经在 Kubernetes 中创建了应用实例,但是在集群外部无法访问它们。为了将流量路由到这些应用实例,我们需要创建一个 Kubernetes 服务对象。以下是服务对象的 YAML 简介:
----------- -- ----- ------- --------- ----- ------------- ----- --------- ---- ----- ------ - ----- ---- ----- -- ----------- ---- --------- --- ----- ------------
在 YAML 简介中,我们指定了服务对象的名称、Pod 的选择器以及端口的转发规则。将上面的 YAML 保存为 myapp-service.yaml,并使用以下命令在集群上创建这个服务对象:
------- ----- -- ------------------
这个命令将创建一个负载均衡器,该负载均衡器将路由端口为 80 的流量到运行在 Pod 上的端口 8080 的容器。
- 测试
现在,您已经在 Kubernetes 集群上运行了无状态应用程序。要测试该应用程序,可以获取 LoadBalancer 的 IP 地址,然后在浏览器中访问该地址(例如:http://)以查看您的应用程序是否响应。
结论
在这篇技术文章中,我们学习了在 Kubernetes 集群上托管无状态应用程序的步骤。我们涵盖了 Docker 镜像的创建、Kubernetes 部署对象和服务对象的创建以及在浏览器中测试应用程序的过程。这个过程用到了 Docker、Kubernetes、YAML 和 Shell 等技术的基本概念,对于正在学习 Kubernetes 和容器化应用程序的人来说是非常有用的。
来源:JavaScript中文网 ,转载请注明来源 本文地址:https://www.javascriptcn.com/post/67233a032e7021665e0ee8f2