Kubernetes中的RBAC

目录

    1. Role
    1. ClusterRole
    1. RoleBinding
    1. ClusterRoleBinding
  • 5.启用 RBAC

Kubernetes中的RBAC(Role-Based Access Control,基于角色的访问控制)是一种机制,用于控制集群内资源的访问权限。RBAC允许管理员通过定义角色(Roles和ClusterRoles)并将其绑定到用户或服务账户(通过RoleBindings和ClusterRoleBindings)来精细地管理访问控制。下面是几个关键概念及其示例:

1. Role

Role 是在特定命名空间中定义的一组权限。它规定了用户或服务账户在这个命名空间里能做什么操作。

示例 YAML 配置(创建一个只读角色):

yaml 复制代码
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
  namespace: default
  name: read-only
rules:
- apiGroups: [""] # "" indicates the core API group
  resources: ["pods", "services"]
  verbs: ["get", "list", "watch"]

2. ClusterRole

ClusterRole 类似于 Role,但它定义的是集群级别的权限,不局限于某个命名空间。

示例 YAML 配置(创建一个集群级别的管理角色):

yaml 复制代码
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: cluster-admin-custom
rules:
- apiGroups: ["*"]
  resources: ["*"]
  verbs: ["*"]

3. RoleBinding

RoleBinding 将角色(Role或ClusterRole)绑定到用户或服务账户,且作用于特定命名空间。

示例 YAML 配置(将上述只读角色绑定到一个用户):

yaml 复制代码
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
  name: read-only-binding
  namespace: default
subjects:
- kind: User
  name: alice # 替换为实际用户名
  apiGroup: rbac.authorization.k8s.io
roleRef:
  kind: Role
  name: read-only
  apiGroup: rbac.authorization.k8s.io

4. ClusterRoleBinding

ClusterRoleBinding 同样用于绑定角色,但它是集群级别的,可以应用于所有命名空间。

示例 YAML 配置(将集群级别的角色绑定到服务账户):

yaml 复制代码
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: cluster-admin-binding
subjects:
- kind: ServiceAccount
  name: my-service-account
  namespace: my-namespace
  apiGroup: rbac.authorization.k8s.io
roleRef:
  kind: ClusterRole
  name: cluster-admin-custom
  apiGroup: rbac.authorization.k8s.io

5.启用 RBAC

在启动 Kubernetes API 服务器时,需要通过 --authorization-mode=RBAC 参数来启用 RBAC。

相关推荐
稚辉君.MCA_P8_Java2 小时前
k8s中pod如何调度?
docker·容器·kubernetes
hxdcxy10 小时前
k8s集群
云原生·容器·kubernetes
youmeyoume216510 小时前
k8s +cilium+metallb 集群流量走向
云原生·容器·kubernetes
David爱编程13 小时前
使用DaemonSet部署日志/监控类组件的正确姿势
云原生·容器·kubernetes
__Smile°15 小时前
kubeadm-k8s 中的 etcd 备份与恢复
数据库·docker·云原生·容器·kubernetes·etcd
lovebugs17 小时前
Kubernetes中高效获取Java应用JVM参数的终极指南
后端·docker·kubernetes
郝同学的测开笔记17 小时前
Kubernetes CronJob 详解:配置、原理与实践指南
云原生·kubernetes·自动化运维
船长@Quant21 小时前
开源的现代数据探索和可视化平台:Apache Superset 在 Kubernetes 上安装
kubernetes·dashboard·大数据可视化·apache superset·sql-lab·商业智能工具
__Smile°1 天前
基于 kubeadm 搭建 k8s 集群
linux·运维·docker·云原生·容器·kubernetes
@不会写代码的小张1 天前
k8s核心组件——kubelet详解
云原生·容器·kubernetes