Kubernetes 的 API Server 安全配置 ——HTTPS 和 Token 认证

阅读时长 13 分钟读完

随着 Kubernetes 的广泛应用,越来越多的企业开始加强 Kubernetes 的安全性。Kubernetes 的 API Server 是 Kubernetes 的核心组件之一,因此需要特别关注它的安全性。本篇文章将介绍 Kubernetes 的 API Server 安全配置,主要包括 HTTPS 和 Token 认证。

HTTPS 安全配置

HTTPS 是一种用于加密网络通信的传输协议。在 Kubernetes 中,我们可以使用 HTTPS 来对 API Server 进行加密通信,以确保 API Server 的安全性。

生成 SSL 证书

在进行 HTTPS 安全配置之前,我们需要先生成 SSL 证书。可以使用 openssl 工具来生成 SSL 证书,具体步骤如下:

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

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

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

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

在生成证书的过程中,我们需要设置证书的域名,这里使用了 Kubernetes 默认的 kubernetes

配置 API Server

在生成证书之后,我们需要对 API Server 进行 HTTPS 安全配置。在 /etc/kubernetes/manifests/kube-apiserver.yaml 文件中,我们可以添加如下配置:

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

需要注意的是,上述配置中使用了 /etc/kubernetes/pki/ca.crt 作为客户端证书的 CA 文件,因此需要将 CA 证书复制到所有的节点并重启 kubelet 服务。

Token 认证

除了 HTTPS 加密通信外,Kubernetes 还提供了 Token 认证的方式,以确保 API Server 的访问权限。Token 认证基于预定义的 Token 进行认证,在 Kubernetes 中,可以通过预定义的 Token 来授予相应的访问权限。Token 认证的具体实现方式包括创建 Token 和配置 RBAC Authorization。

创建 Token

在 Kubernetes 中,可以通过 kubeadm 创建预定义的 Token,具体步骤如下:

运行以上命令将创建一个 Token,同时输出加入 Kubernetes 集群的命令。

需要注意的是,Token 可以设置过期时间,超时后需要重新创建 Token。

配置 RBAC Authorization

在创建 Token 之后,我们需要在 Kubernetes 中配置 RBAC Authorization,以确保只有被授权的用户可以访问 API Server。

/etc/kubernetes/manifests/kube-apiserver.yaml 文件中,我们可以添加如下 RBAC Authorization 配置:

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

需要注意的是,在 /etc/kubernetes/token/clean-cluster-fjcbk/tokens.csv 文件中,我们需要添加预定义的 Token:

上述配置中设置了访问 Token 的名称为 my token,UID 为 admin,用户组为 system:masters

测试 Token 认证

在完成上述配置之后,我们可以测试 Token 认证是否生效。可以在任意节点上执行以下命令:

此时,如果 Token 认证配置成功,则可以获得集群节点的信息。如果 Token 认证配置不成功,则会提示认证失败的信息。

总结

通过本篇文章的介绍,我们了解了 Kubernetes 的 API Server 安全配置,其中包括 HTTPS 和 Token 认证两种方式。在进行 Kubernetes 的安全配置时,需要根据实际情况进行设置,并加强对 Kubernetes 集群的安全性控制,以确保 Kubernetes 的安全运行。

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

纠错
反馈