Kubernetes创建只读权限的kubeconfig

Kubernetes创建只读权限的kubeconfig

背景:由于openclaw和其他智能体的兴起,使k8s集群的运维巡检效率都得到了提升,但是风险也会提升,因此需要给智能体提供只读权限的kubeconfig配置文件,保证不会私自篡改集群配置

注:由于k8s集群自带具有只读权限的名为 view 的clusterrole,因此我们创建 serviceaccount,并创建 clusterrolebinding 将 view 和我们新建的serviceaccount绑定到一块

特:由于 view 具备的权限有限,不具备查询 ClusterRole 和 ClusterRoleBinding、Role 和 RoleBinding、Secrets 和 Nodes 权限,如果需要这些权限,需要创建更多权限的 clusterrole 来和 serviceaccount 绑定。

ServiceAccount、ClusterRole、clusterRolebinding关系图如下:

1、创建 ServiceAccount

bash 复制代码
kubectl create sa readonly-cos -n kube-system

2、创建clusterrolebinding,将view与sa绑定到一起

yaml 复制代码
# readonly-clusterrolebinding.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: readonly-sa-binding
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: view
subjects:
- kind: ServiceAccount
  name: readonly-cos
  namespace: kube-system
bash 复制代码
 
kubectl apply -f eadonly-clusterrolebinding.yaml

3、创建 ServiceAccount 的长期 Token

yaml 复制代码
# sa-secret.yaml
apiVersion: v1
kind: Secret
metadata:
  name: readonly-cos-secret
  namespace: kube-system
  annotations:
    kubernetes.io/service-account.name: readonly-cos
type: kubernetes.io/service-account-token
bash 复制代码
kubectl apply -f sa-secret.yaml

TOKEN=$(kubectl get secret readonly-cos-secret -n kube-system -o jsonpath='{.data.token}' | base64 -d)

echo $TOKEN

4、生成kubeconfig文件

4.1、获取集群信息

bash 复制代码
CLUSTER_NAME=$(kubectl config current-context)

API_SERVER=$(kubectl config view --minify -o jsonpath='{.clusters[0].cluster.server}')

CA_DATA=$(kubectl config view --raw -o jsonpath='{.clusters[0].cluster.certificate-authority-data}')

4.2、生成配置文件

bash 复制代码
kubectl config set-cluster cluster-readonly-cos \
  --server=$API_SERVER \
  --certificate-authority=<(echo $CA_DATA | base64 -d) \
  --embed-certs=true \
  --kubeconfig=readonly-kubeconfig
  
  会在当前目录下生成名为readonly-kubeconfig的配置文件

4.3、设置用户凭证

bash 复制代码
kubectl config set-credentials user-readonly-cos \
  --token=$TOKEN \
  --kubeconfig=readonly-kubeconfig

会在配置文件readonly-kubeconfig添加token配置

4.4、设置上下文

bash 复制代码
kubectl config set-context context-readonly-cos \
  --cluster=cluster-readonly-cos \
  --user=user-readonly-cos \
  --kubeconfig=readonly-kubeconfig
  
会在配置文件readonly-kubeconfig配置上下文信息

kubectl config use-context context-readonly-cos --kubeconfig=/zq/readonly/readonly-kubeconfig
输出:Switched to context "context-readonly-cos".

kubectl config current-context --kubeconfig=/zq/readonly/readonly-kubeconfig
输出:context-readonly-cos

4.5、验证

当编辑资源时会提示拒绝

bash 复制代码
[root@master readonly]# kubectl --kubeconfig=/zq/readonly/readonly-kubeconfig edit deploy apisix-dashboard -n apisix
error: deployments.apps "apisix-dashboard" could not be patched: deployments.apps "apisix-dashboard" is forbidden: User "system:serviceaccount:kube-system:readonly-cos" cannot patch resource "deployments" in API group "apps" in the namespace "apisix"
You can run `kubectl replace -f /tmp/kubectl-edit-864880171.yaml` to try this update again.
[root@master readonly]# 

5、添加 node 权限

默认的 view 不带集群节点的权限,因此使用上述生成的kubeconfig查询时会提示拒绝

bash 复制代码
[root@master readonly]# kubectl --kubeconfig=/zq/readonly/readonly-kubeconfig get nodes
Error from server (Forbidden): nodes is forbidden: User "system:serviceaccount:kube-system:readonly-cos" cannot list resource "nodes" in API group "" at the cluster scope

需新建一个clusterrole,并将这个具备node权限的clusterrole也帮到ServiceAccount上

yaml 复制代码
# node-readonly-cos.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: node-readonly-cos
rules:
- apiGroups: [""]
  resources: ["nodes"]
  verbs: ["get", "list", "watch"]
bash 复制代码
kubectl apply -f node-readonly-cos.yaml

创建clusterrolebinding绑定

bash 复制代码
kubectl create clusterrolebinding nodes-readonly-cos \
  --clusterrole=node-readonly-cos \
  --serviceaccount=kube-system:readonly-cos

再次查询node信息就可以了

6、更大权限的clusterrole

yaml 复制代码
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: all-readonly
rules:
- apiGroups: ["*"]
  resources: ["*"]
  verbs: ["get", "list", "watch"]

将此clusterrole绑定到ServiceAccount上,可获得更大的权限:

bash 复制代码
kubectl create clusterrolebinding all-readonly-cos \
  --clusterrole=all-readonly \
  --serviceaccount=kube-system:readonly-cos
相关推荐
java_cj6 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
qq_452396236 天前
第十三篇:《K8s 安全基础:RBAC、ServiceAccount、Pod Security》
java·安全·kubernetes
睡不醒男孩0308236 天前
云原生运维实战:高并发架构下的云原生可观测性、韧性降级与自动化干预体系
数据库·kubernetes·高并发·prometheus·devops·sre·缓存调优
qq_452396236 天前
第十四篇:《K8s 网络模型与 CNI 插件(Calico、Flannel、Cilium)》
网络·kubernetes·php
Hadoop_Liang6 天前
Kubernetes 应用 HTTPS 安全访问配置实践
https·kubernetes
java_cj6 天前
从0到1启动kube-apiserver:深入源码解析API Server启动全流程
docker·容器·kubernetes
Hadoop_Liang6 天前
使用Kubernetes Gateway API实现域名访问应用
容器·kubernetes·gateway
java_cj6 天前
深入kubectl create源码:从YAML到Pod的完整链路拆解
运维·云原生·容器·kubernetes
万能的知了7 天前
K8s到底需不需要GPU节点?集群资源分配的底层逻辑
云原生·容器·kubernetes
卧室小白7 天前
K8S基础-控制器&deploy&pod回滚更新&service
docker·容器·kubernetes