如果 Pod 不符合设定的配置文件,则拒绝 Pod 的准入
Pod 安全准入是 Kubernetes Pod 安全标准 的实现。使用 Pod 安全准入来限制 Pod 的行为。
Red Hat OpenShift Service on AWS 包含 Kubernetes Pod 安全准入。不符合全局或命名空间级别定义的 Pod 安全准入的 Pod 不会被接纳到集群中,也不能运行。
在全局范围内,强制执行 `privileged` 配置文件,并使用 `restricted` 配置文件进行警告和审计。
您也可以在命名空间级别配置 Pod 安全准入设置。
不要在默认项目中运行工作负载或共享对默认项目的访问权限。默认项目保留用于运行核心集群组件。 以下默认项目被认为是高度特权的:`default`、`kube-public`、`kube-system`、`openshift`、`openshift-infra`、`openshift-node`以及其他具有 `openshift.io/run-level` 标签设置为 `0` 或 `1` 的系统创建的项目。依赖于准入插件的功能(例如 Pod 安全准入、安全上下文约束、集群资源配额和镜像引用解析)在高度特权的项目中不起作用。 |
您可以为命名空间配置以下 Pod 安全准入模式
模式 | 标签 | 描述 |
---|---|---|
|
|
如果 Pod 不符合设定的配置文件,则拒绝 Pod 的准入 |
|
|
如果 Pod 不符合设定的配置文件,则记录审计事件 |
|
|
如果 Pod 不符合设定的配置文件,则显示警告 |
您可以将每种 Pod 安全准入模式设置为以下配置文件之一
配置文件 | 描述 |
---|---|
|
限制最少的策略;允许已知的权限提升 |
|
限制最小的策略;防止已知的权限提升 |
|
限制最严格的策略;遵循当前的 Pod 加固最佳实践 |
以下系统命名空间始终设置为 `privileged` Pod 安全准入配置文件
default
kube-public
kube-system
您无法更改这些特权命名空间的 Pod 安全配置文件。
Pod 安全准入标准和安全上下文约束由两个独立的控制器协调和强制执行。这两个控制器使用以下流程独立工作以强制执行安全策略
安全上下文约束控制器可以根据 Pod 分配的 SCC 更改某些安全上下文字段。例如,如果 seccomp 配置文件为空或未设置,并且 Pod 分配的 SCC 强制 `seccompProfiles` 字段为 `runtime/default`,则控制器会将默认类型设置为 `RuntimeDefault`。
安全上下文约束控制器根据匹配的 SCC 验证 Pod 的安全上下文。
Pod 安全准入控制器根据分配给命名空间的 Pod 安全标准验证 Pod 的安全上下文。
除了全局 Pod 安全准入控制配置外,控制器还会根据给定命名空间中服务帐户的 SCC 权限,将 Pod 安全准入控制 `warn` 和 `audit` 标签应用于命名空间。
控制器检查 `ServiceAccount` 对象权限以在每个命名空间中使用安全上下文约束。安全上下文约束 (SCC) 基于其字段值映射到 Pod 安全配置文件;控制器使用这些转换后的配置文件。Pod 安全准入 `warn` 和 `audit` 标签设置为命名空间中最特权的 Pod 安全配置文件,以防止在创建 Pod 时显示警告和记录审计事件。
命名空间标签基于对命名空间本地服务帐户权限的考虑。
直接应用 Pod 可能会使用运行 Pod 的用户的 SCC 权限。但是,在自动标记期间不会考虑用户权限。
您可以为大多数命名空间启用或禁用自动 Pod 安全准入同步。
您无法在系统创建的命名空间上启用 Pod 安全准入同步。有关更多信息,请参见“Pod 安全准入同步命名空间排除”。 |
对于要配置的每个命名空间,请为 `security.openshift.io/scc.podSecurityLabelSync` 标签设置一个值
要在命名空间中禁用 Pod 安全准入标签同步,请将 `security.openshift.io/scc.podSecurityLabelSync` 标签的值设置为 `false`。
运行以下命令
$ oc label namespace <namespace> security.openshift.io/scc.podSecurityLabelSync=false
要在命名空间中启用 Pod 安全准入标签同步,请将 `security.openshift.io/scc.podSecurityLabelSync` 标签的值设置为 `true`。
运行以下命令
$ oc label namespace <namespace> security.openshift.io/scc.podSecurityLabelSync=true
如果此标签已在命名空间上设置,请使用 `--overwrite` 标志覆盖该值。 |
可以在命名空间级别配置 Pod 安全准入设置。对于命名空间上的每种 Pod 安全准入模式,都可以设置要使用的 Pod 安全准入配置文件。
对于要在命名空间上设置的每种 Pod 安全准入模式,请运行以下命令:
$ oc label namespace <namespace> \ (1)
pod-security.kubernetes.io/<mode>=<profile> \ (2)
--overwrite
1 | 将<namespace> 设置为要配置的命名空间。 |
2 | 将<mode> 设置为enforce 、warn 或audit 。将<profile> 设置为restricted 、baseline 或privileged 。 |
当 Kubernetes API 服务器报告 Pod 安全准入控制器审计级别存在 Pod 拒绝时,会触发PodSecurityViolation
警报。此警报持续一天。
查看 Kubernetes API 服务器审计日志以调查已触发的警报。例如,如果全局强制设置为restricted
Pod 安全级别,则工作负载可能会在准入时失败。
有关识别 Pod 安全准入违规审计事件的帮助,请参阅 Kubernetes 文档中的审计注释。