Kubernetes 中使用 Job 执行批量任务

阅读时长 7 分钟读完

背景

在现代云计算环境下,Kubernetes 已经成为了容器编排领域的事实标准。在 Kubernetes 集群中,一个最常见的应用就是数据处理,例如数据挖掘、ETL(Extract-Transform-Load)等任务。这些任务往往需要批量处理大量数据,因此需要有一种批处理机制。

Kubernetes 中的 Job 是一种用于处理一组任务的机制,它将一组 Pod 中的任务封装在一些控制器中。其中,Pod 是一个可以运行容器的最小单位,而 Job 控制器则负责管理 Pod 并确保它们成功运行。

Job 授权

在 Kubernetes 运行 Job 前,需要先授权该 Job 能够运行的权限,一种常见的授权方式是创建一个服务账户并为其授予足够的权限。示例代码如下:

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

---

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

上述代码创建了一个名为 my-service-account 的服务账户,并向其授权了 admin 权限,使其能够对 Kubernetes 集群中的任何资源进行读写和删除操作。

Job 基础知识

Job 是一种 Kubernetes 中的控制器,它是一组无状态的 Pod,这些 Pod 可以在单个节点或多个节点上运行。当 Job 中的某一 Pod 失败时,Job 会自动重试并创建新的 Pod,直到所有任务都成功完成或重试次数超过限制为止。

Job 的生命周期可以分为以下三个主要阶段:

  1. 创建:当创建一个新的 Job 时,需要指定一个 Pod 模板,该模板包括容器映像、命令行参数、环境变量等信息。Job 会自动根据该模板创建一组 Pod,开始执行任务。

  2. 运行:Job 会追踪其所有 Pod 的运行状态,如果某个 Pod 失败了,Job 会自动重启该 Pod,直到任务成功完成。Pod 的运行状态可以通过以下命令查看:

  3. 结束:当所有任务完成后,Job 会自动终止,并且可以将结果输出到 Kubernetes 中,以便进一步处理。

Job 应用示例

假设我们有一个数据处理任务,需要在 Kubernetes 集群上运行。我们可以使用 Job 实现批量处理数据,代码如下:

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

上述代码为创建一个名为 my-job 的 Job,该 Job 使用 Docker 映像 my-image 来执行数据处理任务。任务需要从输入目录 /input 中读取数据,并将结果存储到输出目录 /output 中。其中,我们使用了 persistentVolumeClaim 来挂载输入和输出目录。

data_processing.py 是一个文件处理脚本的示例,代码如下:

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

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

在运行该 Job 之前,我们需要为其创建持久卷和持久卷声明:

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

---

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

---

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

---

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

上述代码为创建了两个持久卷(input-volumeoutput-volume),并为其分别创建了两个持久卷声明(input-claimoutput-claim)。其中,每个持久卷都将被挂载到一个 Kubernetes 节点上的 /mnt/data/input/mnt/data/output 目录。

最后,我们需要在 Kubernetes 集群上运行该 Job:

运行成功后,我们可以使用以下命令查看 Job 中的 Pod 的运行状态:

除此之外,还可以通过以下命令查看 Job 的运行日志:

总结

本文介绍了 Kubernetes 中的 Job 执行批量任务的基础知识和应用示例。在使用 Job 执行任务时,需要为其分配执行所需的权限,并创建持久卷来保存输入和输出数据。使用 Kubernetes 中的 Job 可以大大简化批量任务的处理,提高数据处理和分析效率。

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

纠错
反馈