范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

Kubernetes基础自学系列鉴权

  视频来源:B站《 2021 年末倾力打造 Kubernetes 入门至精通 - 2022 年幸福的开胃菜》
  一边学习一边整理老师的课程内容及试验笔记,并与大家分享,侵权即删,谢谢支持!
  附上汇总贴:Kubernetes基础自学系列 | 汇总_COCOgsta的博客-CSDN博客
  Authorization
  上面认证过程,只是确认通信的双方都确认了对方是可信的,可以相互通信。而鉴权是确定请求方有哪些资源的权限。API Server 目前支持以下几种授权策略 (通过 API Server 的启动参数 "--authorization-mode" 设置)AlwaysDeny:表示拒绝所有的请求,一般用于测试AlwaysAllow:允许接收所有请求,如果集群不需要授权流程,则可以采用该策略ABAC(Attribute-Based Access Control):基于属性的访问控制,表示使用用户配置的授权规则对用户请求进行匹配和控制Webhook:通过调用外部 REST 服务对用户进行授权RBAC(Role-Based Access Control):基于角色的访问控制,现行默认规则RBAC 授权模式
  RBAC(Role-Based Access Control)基于角色的访问控制,在 Kubernetes 1.5 中引入,现行版本成为默认标准。相对其它访问控制方式,拥有以下优势:对集群中的资源和非资源均拥有完整的覆盖整个 RBAC 完全由几个 API 对象完成,同其它 API 对象一样,可以用 kubectl 或 API 进行操作可以在运行时进行调整,无需重启 API Server
  I、RBAC 的 API 资源对象说明
  RBAC 引入了 4 个新的顶级资源对象:Role、ClusterRole、RoleBinding、ClusterRoleBinding,4 种对象类型均可以通过 kubectl 与 API 操作
  需要注意的是 Kubenetes 并不会提供用户管理,那么 User、Group、ServiceAccount 指定的用户又是从哪里来的呢? Kubenetes 组件(kubectl、kube-proxy)或是其他自定义的用户在向 CA 申请证书时,需要提供一个证书请求文件{   "CN": "admin",   "hosts": [],   "key": {     "algo": "rsa",     "size": 2048   },   "names": [     {       "C": "CN",       "ST": "HangZhou",       "L": "XS",       "O": "system:masters",       "OU": "System"     }   ] }
  API Server会把客户端证书的`CN`字段作为User,把names.O字段作为Group
  kubelet 使用 TLS Bootstaping 认证时,API Server 可以使用 Bootstrap Tokens 或者 Token authentication file 验证 =token,无论哪一种,Kubenetes 都会为 token 绑定一个默认的 User 和 Group
  Pod使用 ServiceAccount 认证时,service-account-token 中的 JWT 会保存 User 信息
  有了用户信息,再创建一对角色/角色绑定(集群角色/集群角色绑定)资源对象,就可以完成权限绑定了Role and ClusterRole
  在 RBAC API 中,Role 表示一组规则权限,权限只会增加(累加权限),不存在一个资源一开始就有很多权限而通过 RBAC 对其进行减少的操作;Role 可以定义在一个 namespace 中,如果想要跨 namespace 则可以创建 ClusterRolekind: Role apiVersion: rbac.authorization.k8s.io/v1beta1 metadata:   namespace: default   name: pod-reader rules: - apiGroups: [""] # "" indicates the core API group   resources: ["pods"]   verbs: ["get", "watch", "list"]
  ClusterRole 具有与 Role 相同的权限角色控制能力,不同的是 ClusterRole 是集群级别的,ClusterRole 可以用于:集群级别的资源控制( 例如 node 访问权限 )非资源型 endpoints( 例如 /health 访问 )所有命名空间资源控制(例如 pods )kind: ClusterRole apiVersion: rbac.authorization.k8s.io/v1beta1 metadata:   # "namespace" omitted since ClusterRoles are not namespaced   name: secret-reader rules: - apiGroups: [""]   resources: ["secrets"]   verbs: ["get", "watch", "list"] RoleBinding and ClusterRoleBinding
  RoloBinding 可以将角色中定义的权限授予用户或用户组,RoleBinding 包含一组权限列表(subjects),权限列表中包含有不同形式的待授予权限资源类型(users, groups, or service accounts);RoloBinding 同样包含对被 Bind 的 Role 引用;RoleBinding 适用于某个命名空间内授权,而 ClusterRoleBinding 适用于集群范围内的授权
  将 default 命名空间的 pod-reader Role 授予 jane 用户,此后 jane 用户在 default 命名空间中将具有 pod-reader 的权限kind: RoleBinding apiVersion: rbac.authorization.k8s.io/v1beta1 metadata:   name: read-pods   namespace: default subjects: - kind: User   name: jane   apiGroup: rbac.authorization.k8s.io roleRef:   kind: Role   name: pod-reader   apiGroup: rbac.authorization.k8s.io
  RoleBinding 同样可以引用 ClusterRole 来对当前 namespace 内用户、用户组或 ServiceAccount 进行授权,这种操作允许集群管理员在整个集群内定义一些通用的 ClusterRole,然后在不同的 namespace 中使用 RoleBinding 来引用
  例如,以下 RoleBinding 引用了一个 ClusterRole,这个 ClusterRole 具有整个集群内对 secrets 的访问权限;但是其授权用户 `dave` 只能访问 development 空间中的 secrets(因为 RoleBinding 定义在 development 命名空间)# This role binding allows "dave" to read secrets in the "development" namespace. kind: RoleBinding apiVersion: rbac.authorization.k8s.io/v1beta1 metadata:   name: read-secrets   namespace: dev # This only grants permissions within the "development" namespace. subjects: - kind: User   name: dave   apiGroup: rbac.authorization.k8s.io roleRef:   kind: ClusterRole   name: secret-reader   apiGroup: rbac.authorization.k8s.io
  使用 ClusterRoleBinding 可以对整个集群中的所有命名空间资源权限进行授权;以下 ClusterRoleBinding 样例展示了授权 manager 组内所有用户在全部命名空间中对 secrets 进行访问# This cluster role binding allows anyone in the "manager" group to read secrets in any namespace. kind: ClusterRoleBinding apiVersion: rbac.authorization.k8s.io/v1beta1 metadata:   name: read-secrets-global subjects: - kind: Group   name: manager   apiGroup: rbac.authorization.k8s.io roleRef:   kind: ClusterRole   name: secret-reader   apiGroup: rbac.authorization.k8s.io Resources
  Kubernetes 集群内一些资源一般以其名称字符串来表示,这些字符串一般会在 API 的 URL 地址中出现;同时某些资源也会包含子资源,例如 logs 资源就属于 pods 的子资源,API 中 URL 样例如下GET /api/v1/namespaces/{namespace}/pods/{name}/log
  如果要在 RBAC 授权模型中控制这些子资源的访问权限,可以通过 / 分隔符来实现,以下是一个定义 pods 资资源 logs 访问权限的 Role 定义样例kind: Role apiVersion: rbac.authorization.k8s.io/v1beta1 metadata:   namespace: default   name: pod-and-pod-logs-reader rules: - apiGroups: [""]   resources: ["pods", "pods/log"]   verbs: ["get", "list"] to Subjects
  RoleBinding 和 ClusterRoleBinding 可以将 Role 绑定到 Subjects;Subjects 可以是 groups、users 或者 service accounts
  Subjects 中 Users 使用字符串表示,它可以是一个普通的名字字符串,如 "alice";也可以是 email 格式的邮箱地址,如 "wangyanglinux@163.com";甚至是一组字符串形式的数字 ID 。但是 Users 的前缀 system: 是系统保留的,集群管理员应该确保普通用户不会使用这个前缀格式
  Groups 书写格式与 Users 相同,都为一个字符串,并且没有特定的格式要求;同样 system: 前缀为系统保留实践:创建一个用户只能管理 dev 空间{   "CN": "devuser",   "hosts": [],   "key": {     "algo": "rsa",     "size": 2048   },   "names": [     {       "C": "CN",       "ST": "BeiJing",       "L": "BeiJing",       "O": "k8s",       "OU": "System"     }   ] }  # 下载证书生成工具 wget https://pkg.cfssl.org/R1.2/cfssl_linux-amd64 mv cfssl_linux-amd64 /usr/local/bin/cfssl  wget https://pkg.cfssl.org/R1.2/cfssljson_linux-amd64 mv cfssljson_linux-amd64 /usr/local/bin/cfssljson  wget https://pkg.cfssl.org/R1.2/cfssl-certinfo_linux-amd64 mv cfssl-certinfo_linux-amd64 /usr/local/bin/cfssl-certinfo  cfssl gencert -ca=ca.crt -ca-key=ca.key  -profile=kubernetes /root/devuser-csr.json | cfssljson -bare devuser  # 设置集群参数 export KUBE_APISERVER="https://192.168.88.11:6443" kubectl config set-cluster kubernetes  --certificate-authority=ca.crt  --embed-certs=true  --server=${KUBE_APISERVER}  --kubeconfig=devuser.kubeconfig  # 设置客户端认证参数 kubectl config set-credentials devuser  --client-certificate=devuser.pem  --client-key=devuser-key.pem  --embed-certs=true  --kubeconfig=devuser.kubeconfig  # 设置上下文参数 kubectl config set-context kubernetes  --cluster=kubernetes  --user=devuser  --namespace=dev  --kubeconfig=devuser.kubeconfig  # 设置默认上下文 kubectl config use-context kubernetes --kubeconfig=devuser.kubeconfig  cp -f ./devuser.kubeconfig /root/.kube/config  kubectl create rolebinding devuser-admin-binding --clusterrole=admin --user=devuser --namespace=dev

具备这些功能,才称得上智能微型融合断路器随着5G大数据人工智能物联网等技术的发展,智能微型融合断路器在电力系统的应用会越来越广泛。电力系统对可靠性及自动化提出越来越高的要求,无论是发电输电配电还是用电,都要求实现监测控制泛在电力物联网建设,智能断路器能起到什么作用?日常生活或工业生产都离不开电力的持续稳定供应。随着社会的发展和经济形态的变化,传统的电网行业暴露出可控性低安全风险高运维难度大等一系列问题。国家电网在2019年初提出,着力构建三型智能断路器如何实现智能化?有何意义作为电力系统中较重要的控制元件,智能断路器的智能化是智能设备乃至智能电网的基础。断路器的智能化,靠传感器技术微电子技术和信息传输技术来共同实现。智能控制单元是智能断路器实现智能控制冬季用电安全提醒注意防范火灾,保护人身安全冬季来临,天气逐渐寒冷,家庭用电以及企业用电常处于高峰状态。空气干燥静电增多可燃物堆积以及电路超负荷运载各种安全隐患很难完全杜绝,一旦疏于管理极易造成电气火灾设备损坏等意外事故。目用电安全小常识据国家统计局的统计数据显示,每年因触电事故造成的死亡人数占很大比例。普通人应该具备基本的用电安全常识,日常生活中,要注意以下事项。1。熟悉家庭中的电源总开关在什么地方。当出现插座漏爆款成了?绿厂奇兵机型K9s首销口碑出炉,网友认可度很高又到一年一度的双11电商大促,显然今年手机厂商都准备得很充分,甚至提前几天就开始了预热活动,比如OPPO早早就在开始了不套路双11预热活动,而开门红当天手机销售额就超过了去年双111。43亿元拍得3处萤石探矿权,房地产公司转型进军氟化工行业施达矿业以1。43亿元,拍得普安晴隆3处萤石矿探矿权,进军氟化工科技产业赛道,助力乡村振兴和地方经济高质量发展。施达集团转型升级,进军高科技氟化工行业2021年10月25日下午,在萤石矿项目持续开采中,瑞金市慧敏萤矿有限公司萤石矿项目获审批近日,瑞金市慧敏萤矿有限公司瑞金市慧敏萤石矿开采项目水土保持行政许可承诺书通过了瑞金市行政审批局的审批。项目概况项目名称瑞金市慧敏萤矿有限公司萤石矿开采项目建设单位瑞金市慧敏萤矿有江苏芯氟半导体项目开工建设河口镇紧紧围绕工业强镇目标,多措并举开展招商引资和项目建设。近日,总投资8000万元的河口镇沃凯氟密封科技有限公司二期工程江苏芯氟半导体项目开工建设。该项目计划建设高标准厂房1602021年罗技第四财季强势上涨远超预期,与京东合作成就销量大爆发提起键盘鼠标,很多人都会想到罗技这个电脑外设知名厂商,其主推的鼠标键盘等长期在全球市场上畅销,尤其是罗技G系列游戏鼠标更是游戏玩家的首选装备,如此强劲的品牌实力,罗技每年的财报自然拼多多百亿补贴得罪品牌?多家品牌开始发声明怼拼多多近年来,拼多多发展迅速,凭借百亿补贴福利活动吸引了大批用户入驻。许多商品在拼多多平台上往往可以用全网最低的价格买到。然而近日,多家品牌纷纷发表声明称,拼多多并未获得合法授权。这是怎
学生党适合什么手机,最好是1000以下的?感谢邀请我是科技数码随时答,很高兴能回答这个问题学生党想买个1100元左右的手机,有什么推荐?这个价位的手机,从性能方面来讲的话,配置都不算是很高,高通骁龙660处理器的手机价格都戴上助听器是什么感觉?所有的声音都能听清楚吗?戴上助听器后之前听不到的声音听到了,最开是都会有不适应,觉得声音大了,多了,耳朵有异物感,这些都需要慢慢适应。戴上助听器后还是和正常听力有些差距的,助听器的佩戴效果跟患者的听力损失华为手机升级鸿蒙系统时间表出炉,百款机型,其中有你的吗?华为鸿蒙系统终于来了,官方公布了各类机型的升级计划时间表,华为Mate40系列MateX2P40系列Mate30系列和MatePadPro将在6月2日进行升级。华为Nova6系列N时间表公布!即日起华为近百款设备陆续上鸿蒙6月2日晚,华为正式发布HarmonyOS鸿蒙操作系统,华为鸿蒙手机也正式登场。华为常务董事消费者业务CEO余承东表示,HarmonyOS是新一代智能终端操作系统,依托分布式技术,关于芯片生产线!台积电又自食其言了,美国目的达到了?原创文章全网分发禁止搬运关于芯片生产线众所周知,华为事件之后,芯片问题成为了全球关注的焦点。其实造成这种现象的原因很简单就是,老美对我国半导体企业的芯片限制,从而引发了全球芯片荒。3款旗舰盘点618换手机不能只看优点,能接受哪款缺点更重要换手机究竟如何选?相信绝大多数人给出的建议都是要明确需求要结合预算对比产品卖点看你喜欢什么品牌等等诸如此类的方法。但小编认为此类方式倒是可行,但太低效了。2021年的今天,智能手机还在纠结母亲节送妈妈什么手机?高颜值长续航,这四款可以选择还在纠结母亲节送妈妈什么手机?高颜值长续航,不知道怎么选的可以考虑小编推荐的这四款。第一款红米Note11Pro采用了一块6。67英寸的AMOLED屏幕,支持120Hz的刷新率以及人在美国,刚下飞机知乎宣布全面上线显示用户IP属地知乎作为一个以问答为主的平台,相信大家对一句话特别熟悉,这句话曾经一度成为一个网络热梗,那就是谢邀,人在美国,刚下飞机。可是从今年4月份开始,一切都变了。2022年4月30日,知乎海外创投丨加拿大数字银行NeoFinancial完成1。452亿美元C轮融资,ValarVentures领投据Techcrunch报道,5月5日,加拿大数字银行NeoFinancial宣布,在超过100万客户大关后,公司完成了1。452亿美元(1。85亿加元)的C轮融资。本轮融资由Val华为城市L2交卷!三个激光雷达,40万开卖车东西(公众号chedongxi)作者James地途编辑Juice余承东再放狠话极狐阿尔法SHI版的自动驾驶硬件为全球量产车中的最强者,没有之一。刚刚,极狐和华为深度合作的纯电车极看娃工作两不误360智能摄像机云台7P超清版体验反馈Hello,大家好,我是婉儿,很高兴又见面了!楼主的宝宝两岁多了,因为和队友是双职工,所以白天宝宝主要由婆婆一人照看,之前家里装了智能锁和可视化门铃,每天仅能在手机APP上看到宝宝