看一眼就会的k8s权限管理手把手教学

news2025/8/6 23:33:21

Kubernetes

Kubernetes使用RBAC授权

  • Kubernetes
  • 一、API概述
    • 1.Role 和 ClusterRole
    • 1.RoleBinding和ClusterRoleBinding
  • 二、使用步骤(Role及RoleBinding为例)
    • 1、创建user用户证书
    • 2、创建集群、用户
        • 1、创建集群配置文件
        • 2、创建基于集群和新用户的上下文
    • 3、给yuantu用户授予权限
        • 1、建立角色
        • 2、将角色绑定到用户yuantu
        • 3、使用用户yuantu测试
        • 4、查看role、rolebinding
        • 5、删除权限
    • 4、为linux系统用户k8s-yuantu与k8s集群用户yuantu相关联
        • 1、将集群配置文件copy到系统用户k8s-yuantu的默认目录下,更改文件权限k8s-yuantu
        • 2、切换成k8s-yuantu用户,就可以访问k8s集群中yuantu用户的有权访问的资源

注意: 文章配置的k8s-yuantu用户为linux系统用户; 而yuantu用户为k8s集群中对应的用户。RBAC(Role base access control)基于角色的访问控制

kubectl create deployment nginx --image=nginx -n kube-public

useradd k8s-yuantu
passwd k8s-yuantu
cd /home/k8s-yuantu

在这里插入图片描述

一、API概述

Role #角色,基于名称空间下的资源
RoleBinding #角色绑定,基于名称空间下的资源
ClusterRole #集群角色,基于集群级别下的资源
ClusterRoleBinding #集群角色绑定,基于集群级别下的资源

其中,Role和Role是针对于名称空间级别,授予其所在名称空间范围内的许可权限。而ClusterRole和ClusterRoleBinding是针对于集群级别,授予其所在集群范围内的许可权限。

1.Role 和 ClusterRole

Role是一系列的权限的集合,例如一个Role可以包含读取 Pod 的权限和列出 Pod 的权限, ClusterRole 跟 Role 类似,但是可以在集群中全局使用。

Role只能授予单个namespace 中资源的访问权限。

1.RoleBinding和ClusterRoleBinding

RoleBinding是将Role中定义的权限授予给用户或用户组。它包含一个subjects列表(users,groups ,service accounts),并引用该Role。RoleBinding在某个namespace 内授权,ClusterRoleBinding适用在集群范围内使用。

RoleBinding可以引用相同namespace下定义的Role。

二、使用步骤(Role及RoleBinding为例)

1、创建user用户证书

创建私钥

umask 077; openssl genrsa -out yuantu.key 2048

在这里插入图片描述
创建证书请求

 openssl req -new -key yuantu.key -out yuantu.csr -subj "/CN=yuantu"

在这里插入图片描述

如果定义组,则组可以作为权限分配的主体,比如:
openssl req -new -key yuantu.key -out yuantu.csr -subj "/CN=yuantu/O=yuantu-admin"

角色授权绑定文件可以定义如下:
subjects:

apiGroup: rbac.authorization.k8s.io
kind: Group
name: yuantu-admin

用服务端CA签署并创建证书

openssl x509 -req  -in yuantu.csr -CA /etc/kubernetes/pki/ca.crt  -CAkey /etc/kubernetes/pki/ca.key  -CAcreateserial -out yuantu.crt -days 365
查看证书
openssl x509 -in yuantu.crt -text  -noout

在这里插入图片描述

2、创建集群、用户

export KUBE_APISERVER="https://192.168.122.30:6443"

在这里插入图片描述

1、创建集群配置文件

kubectl config set-cluster kubernetes --certificate-authority=/etc/kubernetes/pki/ca.crt --embed-certs=true --server=${KUBE_APISERVER} --kubeconfig=kube-config

在这里插入图片描述

注意:使用ca.crt证书,作为集群授权证书,当前目录下生成kube-config配置文件

kubectl config set-credentials yuantu --client-certificate=/home/k8s-yuantu/yuantu.crt --embed-certs=true --client-key=/home/k8s-yuantu/yuantu.key --kubeconfig=kube-config

在这里插入图片描述

注意:

  1. 在kube-config集群配置文件中查看user 名为 yuantu
  2. 采用客户端证书和私钥

2、创建基于集群和新用户的上下文

kubectl config set-context yuantu@kubernetes --cluster=kubernetes --user=yuantu --kubeconfig=kube-config

kubectl config use-context yuantu@kubernetes --kubeconfig=kube-config

在这里插入图片描述

注意: 上下文名称为 yuantu@kubernetes
集群名称为kubernetes
用户名称为yuantu

3、给yuantu用户授予权限

1、建立角色

kubectl create role pods-reader  --verb=get,list,watch --resource=pods -n kube-public -o yaml > role-demo.yaml

cat role-demo.yaml

在这里插入图片描述

注:这些资源对象的修改会立即生效的
--verb:是动作名称如:get,list,watch等。
--resource:是资源类型如:pods,deploy,svc等;注意这里如果写入namespaces是无用的,因为role就是在namespace级别的,而namespaces选项是集群级别的。
--dry-run:运行这条命令,但不生效,常用于测试。
--role:是集群中现已存在的role资源对象。
--user:填写集群中现已存在的用户。或创建完rolebinding后创建这个用户。
--clusterrole:是集群中现已存在的clusterrole资源对象。
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
  creationTimestamp: "2022-11-18T03:21:39Z"
  name: pods-reader
  namespace: kube-public
  resourceVersion: "26736"
  selfLink: /apis/rbac.authorization.k8s.io/v1/namespaces/kube-public/roles/pods-reader
  uid: 09e3bf04-913a-46ce-9463-be36e3d24e78
rules:
- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - get
  - list
  - watch

在这里插入图片描述

2、将角色绑定到用户yuantu

kubectl create rolebinding yuantu-read-pods --role=pods-reader --user=yuantu --namespace=kube-public -o yaml > yuantu-read-pods.yaml

cat yuantu-read-pods.yaml

在这里插入图片描述

apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
  creationTimestamp: "2022-11-18T03:21:47Z"
  name: yuantu-read-pods
  namespace: kube-public
  resourceVersion: "26750"
  selfLink: /apis/rbac.authorization.k8s.io/v1/namespaces/kube-public/rolebindings/yuantu-read-pods
  uid: 20e6eff7-0abc-4754-92c7-249b663fb185
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: Role
  name: pods-reader
subjects:
- apiGroup: rbac.authorization.k8s.io
  kind: User
  name: yuantu

在这里插入图片描述

3、使用用户yuantu测试

kubectl config use-context yuantu@kubernetes --kubeconfig=kube-config

在这里插入图片描述

查看权限

kubectl get pods -n kube-public --kubeconfig=kube-config
NAME                     READY   STATUS    RESTARTS   AGE
nginx-554b9c67f9-xrxl6   1/1     Running   0          15m

在这里插入图片描述

其他无权限

kubectl get pods --kubeconfig=kube-config
kubectl get deployment --kubeconfig=kube-config
Error from server (Forbidden): pods is forbidden: User "yuantu" cannot list resource "pods" in API group "" in the namespace "default"

Error from server (Forbidden): deployments.extensions is forbidden: User "yuantu" cannot list resource "deployments" in API group "extensions" in the namespace "default"

在这里插入图片描述

4、查看role、rolebinding

kubectl get role -n kube-public
NAME                                   AGE
kubeadm:bootstrap-signer-clusterinfo   21d
pods-reader                            7m39s
system:controller:bootstrap-signer     21d
kubectl get rolebinding -n kube-public
NAME                                   AGE
kubeadm:bootstrap-signer-clusterinfo   21d
system:controller:bootstrap-signer     21d
yuantu-read-pods                       9m58s

在这里插入图片描述

5、删除权限

解除角色绑定

kubectl delete rolebinding yuantu-read-pods -n kube-public
rolebinding.rbac.authorization.k8s.io "yuantu-read-pods" deleted

删除角色

kubectl delete role pods-reader -n kube-public
role.rbac.authorization.k8s.io "pods-reader" deleted

在这里插入图片描述

4、为linux系统用户k8s-yuantu与k8s集群用户yuantu相关联

1、将集群配置文件copy到系统用户k8s-yuantu的默认目录下,更改文件权限k8s-yuantu

mkdir /home/k8s-yuantu/.kube && cp kube-config /home/k8s-yuantu/.kube/config

chown -R k8s-yuantu.k8s-yuantu /home/k8s-yuantu

2、切换成k8s-yuantu用户,就可以访问k8s集群中yuantu用户的有权访问的资源

su k8s-yuantu
kubectl get pods  -n kube-public
NAME                     READY   STATUS    RESTARTS   AGE
nginx-554b9c67f9-xrxl6   1/1     Running   0          40m

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/15726.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【java进阶02:抽象类和接口】类与类之间的关系 抽象类与接口的区别

目录 抽象类 接口 抽象类 什么是抽象类 /*类————>对象 :实例化 对象————>类 :抽象抽象类:1、什么是抽象类?类和类之间具有共同特征,将这些共同特征提取出来,形成的就是抽象类类本身是不存在的&…

python 实现MAC泛洪与ARP欺骗

声明:本文章的一切内容仅用于交流与学习 目录 一、Python scapy 二、MAC泛洪 三、ARP欺骗 一、Python scapy scapy提供了构造、发送、接收、分析数据包的功能 scapy的内容很多这里只说明要用到的内容 RandMAC:自动生成一个随机的MAC地址 packet Et…

【SpringBoot】idea创建SpringBoot项目及注解配置相关应用

文章目录SpringBoot:一、简言二、SpringBoot作用三、核心功能四、创建springBoot项目1、新建SpringBoot(maven基础下)2、next---选版本导jar包3、创建后的pom.xml4、SpringBoot启动类六、测试项目1.项目构建:2.数据源注入dao层---…

【爬虫系列】Python爬虫实战--招聘网站的职位信息爬取

一、分析 1. 需求分析 从网上找工作,大家一般都会通过各种招聘网站去检索相关信息,今天利用爬虫采集招聘网站的职位信息,比如岗位名称,岗位要求,薪资,公司名称,公司规模,公司位置&…

状态机总结(简洁)

一、概念 状态机简写为 FSM(Finite State Machine),也称为同步有限状态机,我们一般简称为状态机,之所以说“同步”是因为状态机中所有的状态跳转都是在时钟的作用下进行的,而“有限”则是说状态的个数是有…

【面试题】绝对定位和相对定位

absolute和relative分别依据什么定位&#xff1f; relative依据自身定位absolute依据最近一层的定位元素定位&#xff0c;如果上层没有定位元素&#xff0c;则依据body定位 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8&…

学C/C++想提升功底 可以花点时间看看这篇博客---C语言程序环境和预处理

本篇博客介绍了C语言程序环境和预处理.主要包含程序的翻译和运行环境和 各种预处理操作:预定义符号.各种#define 用法 undef的使用条件编译的使用 头文件包含指令 C语言程序环境和预处理一.程序的翻译环境和执行环境1.翻译环境2.运行环境二.预处理详解1.预定义符号2.#define的用…

Winform 自动升级程序

抽时间整理下升级这块的功能&#xff0c;并封装一个升级工具包。 作为winform 程序员都有一个C/S端程序绕不过的问题。那就是如何升级程序&#xff1f; 程序升级两种1.启动时强制更新 2.自动、手动获取更新&#xff0c;并确认是否升级。 今天咱们介绍&#xff0c;自动或者手…

路由进阶:route-policy实验配置

实验拓扑 网络拓扑及IP编址如上图所示&#xff1b;R1、R2运行RIPv2&#xff0c;R2、R3运行OSPF。R1上开设三个Loopback接口&#xff0c;地址分别是192.168.1.1/24、192.168.2.1/24及192.168.3.1/24&#xff0c;R1并没有在这三个接口上激活RIPv2&#xff1b; 实验需求 R1在RIP…

[附源码]计算机毕业设计JAVA航空售票管理系统

[附源码]计算机毕业设计JAVA航空售票管理系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybati…

智慧安防解决方案-最新全套文件

智慧安防解决方案-最新全套文件一、建设背景二、思路架构三、建设方案二、获取 - 智慧安防全套最新解决方案合集一、建设背景 随着经济的发展和城市建设速度的加快&#xff0c;全球各地区的安全问题接踵而至&#xff0c;我国正进入“突发公共事件的高发期”和“社会高风险期”…

LabVIEW性能和内存管理 6

LabVIEW性能和内存管理 6 本文介绍LabVIEW性能和内存管理的几个建议6。 数据空间Dataspaces VI的数据存储在它的数据空间中 每个VI都有自己的数据空间 可重入VIs有多个数据空间 可重入性和数据空间 不可重入的 每个调用共享一个数据空间 一次只能执行一个调用 …

如何把PDF转换成Word文档?给大家分享三种转换方法

如何将PDF文件的格式转换成Word文档来使用呢&#xff1f;对文件的格式转换&#xff0c;相信大家最常转换格式的文件就是这两种了&#xff0c;因为它们存在我们日常的各个角落。我们在工作中需要使用Word来编辑文字&#xff0c;发送或者是下载文件&#xff0c;基本都是PDF格式。…

EN 16034门窗及配件—CE认证

门窗及配件CE认证&#xff08;欧盟强制认证&#xff09;&#xff0d;简介 在欧盟市场“CE”标志属强制性认证标志&#xff0c;以表明产品符合欧盟《技术协调与标准化新方法》指令的基本要求。这是欧盟法律对产品提出的一种强制性要求。 在门窗及配件上加贴CE标志不但可以证明其…

从零开始学习Linux(1)

Linux基本操作 文章目录Linux基本操作前言一、操作系统相关知识1.什么是操作系统&#xff1f;2.操作系统有什么作用二、Linux基本操作1.ls指令2.pwd命令3.cd命令3.热键4.touch指令5.nano指令6.start指令7.mkdir指令&#xff08;重要&#xff09;8.rmdir指令&&rm指令&am…

蓝牙学习二(连接和通讯简述)

1.简介 蓝牙的通信是双向的&#xff0c;为了创建和维护一个BLE通信连接&#xff0c;在蓝牙中引入了“角色”这一概念&#xff0c;一个BLE设备不是主机&#xff08;集中器&#xff09;就是从机&#xff08;外围设备&#xff09;角色&#xff0c;这是根据是谁发起这个连接来确定的…

JVM - G1收集器、Region、停顿时间模型、垃圾回收(建议收藏)

​ 编辑切换为居中 添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; Region 使用G1收集器时&#xff0c;java堆的内存会划分为多个大小相等的独立区域&#xff08;Region&#xff09;&#xff0c;Region中也有新生代和老年代的概念&#xff0c;但是新生…

Source Insight是一个面向项目开发的程序编辑器和代码浏览器丨产品简介

Source Insight是为大型、高要求的现实世界编程项目而设计的。事实上&#xff0c;今天&#xff0c;重要的技术公司正在使用Source Insight来开发一些最大、最成功的商业硬件和软件产品。 代码分析 Source Insight会在您工作时动态解析您的源代码并维护自己的符号信息数据库&a…

Redis实战篇(六)用户签到、UV统计

一、用户签到 1、BitMap用法 我们按月来统计用户签到信息&#xff0c;签到记录为1&#xff0c;未签订则记录为0。 把每一个bit位对应每月的一天&#xff0c;形成映射关系。用0和1标识业务状态&#xff0c;这种思路称为位图&#xff08;BitMap&#xff09;。 Redis中利用strin…

qt qml

QT Quick是QT提供的一种高级用户界面工具包&#xff0c;包含对QML完美支持. Qt Quick 就是使用 QML 构建的一套类库。 Qml模块本身并没有涉及图形显示&#xff0c;所有的图形处理都由Qt Quick模块完成。 QMl是一种高效的开发UI 的语言。QML&#xff08;Qt Meta-Object Languag…