k8srbac 详解

一、什么是 k8srbac

k8srbac 全称 Kubernetes Role-Based Access Control(基于角色的访问控制),它是 Kubernetes 集群中的一种访问控制机制。通过 k8srbac,可以在 Kubernetes 集群中实现权限的细分与管理,从而提高集群的安全性。

二、k8srbac 相关术语

在了解 k8srbac 的细节之前,先来了解 k8srbac 相关的术语。下面列出了 k8srbac 中比较重要的一些角色和资源:

  • Subject: 能够对 Kubernetes 资源进行访问的主体,可以是一个用户或者一个服务账户。
  • Role: 角色代表了一组权限操作,例如可以创建、更新或删除一个或多个资源。在 Kubernetes 中,角色只作用于指定的 Namespace。
  • ClusterRole: ClusterRole 与 Role 类似,但是作用于整个 Kubernetes 集群。
  • RoleBinding: 用于将 Role 与 Subject 进行绑定,从而赋予 Subject 对 Role 所代表的资源的权限。
  • ClusterRoleBinding: 与 RoleBinding 类似,但是作用于整个 Kubernetes 集群,可以将 ClusterRole 与各种 Subject 进行绑定。

三、k8srbac 角色权限设置示例

下面我们通过一个示例来展示如何使用 k8srbac 角色进行权限设置。假设我们有一个 Kubernetes 应用,它只需要访问该 Cluster 的前端应用资源(例如 Ingress 和 Service),不需要访问其他类型的资源。针对这种场景,我们可以创建如下的 k8srbac 角色:

kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  namespace: default
  name: frontend-role
rules:
- apiGroups:
  - networking.k8s.io
  resources:
  - ingresses
  verbs:
  - get
  - list
  - watch
- apiGroups:
  - ""
  resources:
  - services
  verbs:
  - get
  - list
  - watch

在上面的 k8srbac 角色定义中,我们设置了两个规则:

  • 允许读取 Ingress 资源。
  • 允许读取 Service 资源。

接下来,我们需要将该角色与 Subject 绑定起来。假设我们有一个名为 frontend-svcaccount 的 ServiceAccount,可以通过如下的 RoleBinding 进行绑定:

kind: RoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: frontend-rolebinding
  namespace: default
subjects:
- kind: ServiceAccount
  name: frontend-svcaccount
  apiGroup: ""
roleRef:
  kind: Role
  name: frontend-role
  apiGroup: ""

在上面的 RoleBinding 中,我们将 ServiceAccount frontend-svcaccount 与 Role frontend-role 进行了绑定。这样,frontend-svcaccount 就可以读取 Ingress 和 Service 资源了。

四、k8srbac ClusterRole 的使用示例

除了使用 Role 进行 Namespace 级别的权限控制之外,我们还可以使用 ClusterRole 进行 Kubernetes 集群级别的权限控制。下面我们来看一个例子,假设我们需要给某个账号(假设该账号名字为 devops)赋予下列权限:

  • 读取 Node 资源。
  • 读取 ConfigMap、Secret、Event 和 Pod 资源。
  • 读取、创建和删除 Namespace 资源。
  • 创建、更新和删除 Pod 和 Service 资源。
  • 更新和删除 Deployment 和 StatefulSet 资源。

我们可以创建如下的 ClusterRole:

kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: devops-cluster-role
rules:
- apiGroups: [""]
  resources: ["nodes"]
  verbs: ["get", "watch", "list"]
- apiGroups: [""]
  resources: ["configmaps", "secrets", "events", "pods"]
  verbs: ["get", "watch", "list"]
- apiGroups: [""]
  resources: ["namespaces"]
  verbs: ["get", "create", "delete"]
- apiGroups: [""]
  resources: ["pods", "services"]
  verbs: ["get", "create", "delete"]
- apiGroups: ["apps"]
  resources: ["deployments", "statefulsets"]
  verbs: ["update", "delete"]

接下来,我们需要将该 ClusterRole 与 devops 账号进行绑定。可以通过如下的 ClusterRoleBinding 完成绑定:

kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: devops-clusterrolebinding
subjects:
- kind: User
  name: devops
  apiGroup: rbac.authorization.k8s.io
roleRef:
  kind: ClusterRole
  name: devops-cluster-role
  apiGroup: rbac.authorization.k8s.io

在上面的 ClusterRoleBinding 中,我们将 devops 账号与 devops-cluster-role 进行了绑定。这样,devops 账号就可以读取和修改被该 ClusterRole 所授权的 Kubernetes 资源了。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/257805.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝的头像小蓝
上一篇 2024-12-15 12:46
下一篇 2024-12-15 12:47

相关推荐

  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25
  • MPU6050工作原理详解

    一、什么是MPU6050 MPU6050是一种六轴惯性传感器,能够同时测量加速度和角速度。它由三个传感器组成:一个三轴加速度计和一个三轴陀螺仪。这个组合提供了非常精细的姿态解算,其…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • Java BigDecimal 精度详解

    一、基础概念 Java BigDecimal 是一个用于高精度计算的类。普通的 double 或 float 类型只能精确表示有限的数字,而对于需要高精度计算的场景,BigDeci…

    编程 2025-04-25
  • C语言贪吃蛇详解

    一、数据结构和算法 C语言贪吃蛇主要运用了以下数据结构和算法: 1. 链表 typedef struct body { int x; int y; struct body *nex…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25

发表回复

登录后才能评论