Kubernetes集群故障排查—审计

简介: Kubernetes集群故障排查—审计

 Kubernetes 审计(Auditing) 功能提供了与安全相关的、按时间顺序排列的记录集, 记录每个用户、使用 Kubernetes API 的应用以及控制面自身引发的活动。

审计功能使得集群管理员能够回答以下问题:

    • 发生了什么?
    • 什么时候发生的?
    • 谁触发的?
    • 活动发生在哪个(些)对象上?
    • 在哪观察到的?
    • 它从哪触发的?
    • 活动的后续处理行为是什么?

    审计记录最初产生于 kube-apiserver 内部。每个请求在不同执行阶段都会生成审计事件;这些审计事件会根据特定策略被预处理并写入后端。 策略确定要记录的内容和用来存储记录的后端,当前的后端支持日志文件和 webhook。

    每个请求都可被记录其相关的阶段(stage)。已定义的阶段有:

      • RequestReceived - 此阶段对应审计处理器接收到请求后, 并且在委托给其余处理器之前生成的事件。
      • ResponseStarted - 在响应消息的头部发送后,响应消息体发送前生成的事件。 只有长时间运行的请求(例如 watch)才会生成这个阶段。
      • ResponseComplete - 当响应消息体完成并且没有更多数据需要传输的时候。
      • Panic - 当 panic 发生时生成。

      说明:

      审计事件配置 的配置与 Event API 对象不同。

      审计日志记录功能会增加 API server 的内存消耗,因为需要为每个请求存储审计所需的某些上下文。 内存消耗取决于审计日志记录的配置。

      审计策略

      审计策略定义了关于应记录哪些事件以及应包含哪些数据的规则。 审计策略对象结构定义在 audit.k8s.io API 组。 处理事件时,将按顺序与规则列表进行比较。第一个匹配规则设置事件的审计级别(Audit Level)。 已定义的审计级别有:

        • None - 符合这条规则的日志将不会记录。
        • Metadata - 记录请求的元数据(请求的用户、时间戳、资源、动词等等), 但是不记录请求或者响应的消息体。
        • Request - 记录事件的元数据和请求的消息体,但是不记录响应的消息体。 这不适用于非资源类型的请求。
        • RequestResponse - 记录事件的元数据,请求和响应的消息体。这不适用于非资源类型的请求。

        你可以使用 --audit-policy-file 标志将包含策略的文件传递给 kube-apiserver。 如果不设置该标志,则不记录事件。 注意 rules 字段必须在审计策略文件中提供。没有(0)规则的策略将被视为非法配置。

        以下是一个审计策略文件的示例:

        audit/audit-policy.yaml

        转存失败重新上传取消image.gif编辑

        apiVersion: audit.k8s.io/v1 # 这是必填项。
        kind: Policy
        # 不要在 RequestReceived 阶段为任何请求生成审计事件。
        omitStages:
          - "RequestReceived"
        rules:
          # 在日志中用 RequestResponse 级别记录 Pod 变化。
          - level: RequestResponse
            resources:
            - group: ""
              # 资源 "pods" 不匹配对任何 Pod 子资源的请求,
              # 这与 RBAC 策略一致。
              resources: ["pods"]
          # 在日志中按 Metadata 级别记录 "pods/log"、"pods/status" 请求
          - level: Metadata
            resources:
            - group: ""
              resources: ["pods/log", "pods/status"]
          # 不要在日志中记录对名为 "controller-leader" 的 configmap 的请求。
          - level: None
            resources:
            - group: ""
              resources: ["configmaps"]
              resourceNames: ["controller-leader"]
          # 不要在日志中记录由 "system:kube-proxy" 发出的对端点或服务的监测请求。
          - level: None
            users: ["system:kube-proxy"]
            verbs: ["watch"]
            resources:
            - group: "" # core API 组
              resources: ["endpoints", "services"]
          # 不要在日志中记录对某些非资源 URL 路径的已认证请求。
          - level: None
            userGroups: ["system:authenticated"]
            nonResourceURLs:
            - "/api*" # 通配符匹配。
            - "/version"
          # 在日志中记录 kube-system 中 configmap 变更的请求消息体。
          - level: Request
            resources:
            - group: "" # core API 组
              resources: ["configmaps"]
            # 这个规则仅适用于 "kube-system" 名字空间中的资源。
            # 空字符串 "" 可用于选择非名字空间作用域的资源。
            namespaces: ["kube-system"]
          # 在日志中用 Metadata 级别记录所有其他名字空间中的 configmap 和 secret 变更。
          - level: Metadata
            resources:
            - group: "" # core API 组
              resources: ["secrets", "configmaps"]
          # 在日志中以 Request 级别记录所有其他 core 和 extensions 组中的资源操作。
          - level: Request
            resources:
            - group: "" # core API 组
            - group: "extensions" # 不应包括在内的组版本。
          # 一个抓取所有的规则,将在日志中以 Metadata 级别记录所有其他请求。
          - level: Metadata
            # 符合此规则的 watch 等长时间运行的请求将不会
            # 在 RequestReceived 阶段生成审计事件。
            omitStages:
              - "RequestReceived"

        image.gif

        你可以使用最低限度的审计策略文件在 Metadata 级别记录所有请求:

        # 在 Metadata 级别为所有请求生成日志
        apiVersion: audit.k8s.io/v1beta1
        kind: Policy
        rules:
        - level: Metadata

        image.gif

        如果你在打磨自己的审计配置文件,你可以使用为 Google Container-Optimized OS 设计的审计配置作为出发点。你可以参考 configure-helper.sh 脚本,该脚本能够生成审计策略文件。你可以直接在脚本中看到审计策略的绝大部份内容。

        你也可以参考 Policy 配置参考 以获取有关已定义字段的详细信息。

        审计后端

        审计后端实现将审计事件导出到外部存储。kube-apiserver 默认提供两个后端:

          • Log 后端,将事件写入到文件系统
          • Webhook 后端,将事件发送到外部 HTTP API

          在这所有情况下,审计事件均遵循 Kubernetes API 在 audit.k8s.io API 组 中定义的结构。

          说明:

          对于 patch 请求,请求的消息体需要是设定 patch 操作的 JSON 所构成的一个串, 而不是一个完整的 Kubernetes API 对象的 JSON 串。 例如,以下的示例是一个合法的 patch 请求消息体,该请求对应 /apis/batch/v1/namespaces/some-namespace/jobs/some-job-name:

          [
            {
              "op": "replace",
              "path": "/spec/parallelism",
              "value": 0
            },
            {
              "op": "remove",
              "path": "/spec/template/spec/containers/0/terminationMessagePolicy"
            }
          ]

          image.gif

          Log 后端

          Log 后端将审计事件写入 JSONlines 格式的文件。 你可以使用以下 kube-apiserver 标志配置 Log 审计后端:

            • --audit-log-path 指定用来写入审计事件的日志文件路径。不指定此标志会禁用日志后端。- 意味着标准化
            • --audit-log-maxage 定义保留旧审计日志文件的最大天数
            • --audit-log-maxbackup 定义要保留的审计日志文件的最大数量
            • --audit-log-maxsize 定义审计日志文件轮转之前的最大大小(兆字节)

            如果你的集群控制面以 Pod 的形式运行 kube-apiserver,记得要通过 hostPath 卷来访问策略文件和日志文件所在的目录,这样审计记录才会持久保存下来。例如:

            - --audit-policy-file=/etc/kubernetes/audit-policy.yaml
              - --audit-log-path=/var/log/kubernetes/audit/audit.log

            image.gif

            接下来挂载数据卷:

            ...
            volumeMounts:
              - mountPath: /etc/kubernetes/audit-policy.yaml
                name: audit
                readOnly: true
              - mountPath: /var/log/kubernetes/audit/
                name: audit-log
                readOnly: false

            image.gif

            最后配置 hostPath:

            ...
            volumes:
            - name: audit
              hostPath:
                path: /etc/kubernetes/audit-policy.yaml
                type: File
            - name: audit-log
              hostPath:
                path: /var/log/kubernetes/audit/
                type: DirectoryOrCreate

            image.gif

            Webhook 后端

            Webhook 后端将审计事件发送到远程 Web API,该远程 API 应该暴露与 kube-apiserver 形式相同的 API,包括其身份认证机制。你可以使用如下 kube-apiserver 标志来配置 Webhook 审计后端:

              • --audit-webhook-config-file 设置 Webhook 配置文件的路径。Webhook 配置文件实际上是一个 kubeconfig 文件。
              • --audit-webhook-initial-backoff 指定在第一次失败后重发请求等待的时间。随后的请求将以指数退避重试。

              Webhook 配置文件使用 kubeconfig 格式指定服务的远程地址和用于连接它的凭据。

              事件批处理

              日志和 Webhook 后端都支持批处理。以 Webhook 为例,以下是可用参数列表。要获取日志 后端的同样参数,请在参数名称中将 webhook 替换为 log。 默认情况下,在 webhook 中批处理是被启用的,在 log 中批处理是被禁用的。 同样,默认情况下,在 webhook 中启用带宽限制,在 log 中禁用带宽限制。

                • --audit-webhook-mode 定义缓存策略,可选值如下:batch - 以批处理缓存事件和异步的过程。这是默认值。blocking - 在 API 服务器处理每个单独事件时,阻塞其响应。blocking-strict - 与 blocking 相同,不过当审计日志在 RequestReceived 阶段失败时,整个 API 服务请求会失效。

                以下参数仅用于 batch 模式:

                  • --audit-webhook-batch-buffer-size 定义 batch 之前要缓存的事件数。 如果传入事件的速率溢出缓存区,则会丢弃事件。
                  • --audit-webhook-batch-max-size 定义一个 batch 中的最大事件数。
                  • --audit-webhook-batch-max-wait 无条件 batch 队列中的事件前等待的最大事件。
                  • --audit-webhook-batch-throttle-qps 每秒生成的最大批次数。
                  • --audit-webhook-batch-throttle-burst 在达到允许的 QPS 前,同一时刻允许存在的最大 batch 生成数。

                  参数调整

                  需要设置参数以适应 API 服务器上的负载。

                  例如,如果 kube-apiserver 每秒收到 100 个请求,并且每个请求仅在 ResponseStarted 和 ResponseComplete 阶段进行审计,则应该考虑每秒生成约 200 个审计事件。 假设批处理中最多有 100 个事件,则应将限制级别设置为每秒至少 2 个查询。 假设后端最多需要 5 秒钟来写入事件,你应该设置缓冲区大小以容纳最多 5 秒的事件, 即 10 个 batch,即 1000 个事件。

                  但是,在大多数情况下,默认参数应该足够了,你不必手动设置它们。 你可以查看 kube-apiserver 公开的以下 Prometheus 指标,并在日志中监控审计子系统的状态。

                    • apiserver_audit_event_total 包含所有暴露的审计事件数量的指标。
                    • apiserver_audit_error_total 在暴露时由于发生错误而被丢弃的事件的数量。

                    日志条目截断

                    日志后端和 Webhook 后端都支持限制所输出的事件大小。 例如,下面是可以为日志后端配置的标志列表:

                    • audit-log-truncate-enabled:是否弃用事件和批次的截断处理。
                    • audit-log-truncate-max-batch-size:向下层后端发送的各批次的最大字节数。
                    • audit-log-truncate-max-event-size:向下层后端发送的审计事件的最大字节数。

                    默认情况下,截断操作在 webhook 和 log 后端都是被禁用的,集群管理员需要设置 audit-log-truncate-enabled 或 audit-webhook-truncate-enabled 标志来启用此操作。






                    文章下方有交流学习区!一起学习进步!也可以前往官网,加入官方微信交流群 你的支持和鼓励是我创作的动力❗❗❗

                    Doker的成长,欢迎大家一起陪伴!!!

                    我发好文,兄弟们有空请把我的官方旗舰店流量撑起来!!!

                    官网:Doker 多克; 官方旗舰店Doker 多克 官方旗舰店-淘宝网 全品优惠


                    相关实践学习
                    容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
                    通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
                    云原生实践公开课
                    课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
                    目录
                    相关文章
                    |
                    2天前
                    |
                    Kubernetes Cloud Native 微服务
                    微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
                    微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
                    12 3
                    |
                    14天前
                    |
                    Kubernetes 微服务 容器
                    Aspire项目发布到远程k8s集群
                    Aspire项目发布到远程k8s集群
                    48 2
                    Aspire项目发布到远程k8s集群
                    |
                    4天前
                    |
                    Kubernetes 数据处理 调度
                    天呐!部署 Kubernetes 模式的 Havenask 集群太震撼了!
                    【6月更文挑战第11天】Kubernetes 与 Havenask 集群结合,打造高效智能的数据处理解决方案。Kubernetes 如指挥家精准调度资源,Havenask 快速响应查询,简化复杂任务,优化资源管理。通过搭建 Kubernetes 环境并配置 Havenask,实现高可扩展性和容错性,保障服务连续性。开发者因此能专注业务逻辑,享受自动化基础设施管理带来的便利。这项创新技术组合引领未来,开启数据处理新篇章。拥抱技术新时代!
                    |
                    4天前
                    |
                    Kubernetes 前端开发 Serverless
                    Serverless 应用引擎产品使用合集之如何调用Kubernetes集群内服务
                    阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
                    |
                    13天前
                    |
                    容器 Perl Kubernetes
                    深入 Kubernetes 网络:实战K8s网络故障排查与诊断策略
                    本文介绍了Kubernetes网络的基础知识和故障排查经验,重点讨论了私有化环境中Kubernetes网络的挑战。首先,文章阐述了Kubernetes网络模型的三大核心要素:Pod网络、Service网络和CNI,并强调了其在容器通信和服务发现中的作用。接着,通过三个具体的故障案例,展示了网络冲突、主节点DNS配置更改导致的服务中断以及容器网络抖动问题的解决过程,强调了网络规划、配置管理和人员培训的重要性。最后,提到了KubeSkoop exporter工具在监控和定位网络抖动问题中的应用。通过这些案例,读者可以深入了解Kubernetes网络的复杂性,并学习到实用的故障排查方法。
                    146182 18
                    |
                    15天前
                    |
                    运维 Kubernetes 调度
                    【kubernetes】关于k8s集群的污点、容忍、驱逐以及k8s集群故障排查思路
                    【kubernetes】关于k8s集群的污点、容忍、驱逐以及k8s集群故障排查思路
                    |
                    19天前
                    |
                    运维 监控 Linux
                    提升系统稳定性:Linux服务器性能监控与故障排查实践深入理解与实践:持续集成在软件测试中的应用
                    【5月更文挑战第27天】在互联网服务日益增长的今天,保障Linux服务器的性能和稳定性对于企业运维至关重要。本文将详细探讨Linux服务器性能监控的工具选择、故障排查流程以及优化策略,旨在帮助运维人员快速定位问题并提升系统的整体运行效率。通过实际案例分析,我们将展示如何利用系统资源监控、日志分析和性能调优等手段,有效预防和解决服务器性能瓶颈。
                    |
                    7月前
                    |
                    运维 前端开发 JavaScript
                    基于 Angular Universal 引擎进行服务器端渲染的前端应用 State Transfer 故障排查案例
                    基于 Angular Universal 引擎进行服务器端渲染的前端应用 State Transfer 故障排查案例
                    232 0