CKS 题库 14、启用API server认证
Context
由 kubeadm 创建的 cluster 的 Kubernetes API 服务器,出于测试目的, 临时配置允许未经身份验证和未经授权的访问,授予匿名用户 cluster-admin 的访问权限.
Task
重新配置 cluster 的 Kubernetes APl 服务器,以确保只允许经过身份验证和授权的 REST 请求。 使用授权模式 Node , RBAC 和准入控制器 NodeRestriction 。 删除用户 system:anonymous 的 ClusterRoleBinding 来进行清理。
注意:所有 kubectl 配置环境/文件也被配置使用未经身份验证和未经授权的访问。 你不必更改它,但请注意,一旦完成 cluster 的安全加固, kubectl 的配置将无法工作。 您可以使用位于 cluster 的 master 节点上,cluster 原本的 kubectl 配置文件 /etc/kubernetes/admin.conf ,以确保经过身份验证的授权的请求仍然被允许。
模拟环境里,初始化这道题的脚本为b.sh
参考
https://kubernetes.io/zh/docs/reference/command-line-tools-reference/kube-apiserver/
解答
切换集群
kubectl config use-context KSCF00301 |
远程到 master 并切换到 root
ssh master01 |
确保只有认证并且授权过的REST请求才被允许 /etc/kubernetes/manifests/kube-apiserver.yaml
- --authorization-mode=AlwaysAllow |
修改为
- --authorization-mode=Node,RBAC |
重启kubelet
systemctl daemon-reload |
删除题目要求的角色绑定
kubectl get clusterrolebinding system:anonymous #检查 |
验证
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 Hao DevSecOps!
评论



