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

Kubernetes入门至精通Kubernetes集群安全鉴权

  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

京东物流绿起来物流车转向电动化,技术园区多路径减碳自从更换了电动物流车之后,最明显的就是装车时候再也没有燃油车呛鼻的尾气味道了。我们在2017年就把北京的自营城配车辆全部更换为新能源车辆了。最近这批车已经到了年头,刚完成了一批新车春节前想给家里换新,有哪些值得置办的电器?要问买什么电器最值当?要买就买划算实用的家用电器,刚好趁着新年为家中老旧的电器做一次更新换代,让家里焕然一新。要说近几年好评度较高和性价比较高的家用电器我推荐烟机万和CXW310L网信办规范换脸语音合成等深度合成技术必须提供真实身份信息,内容需审核并可追溯1月28日,网信办起草了互联网信息服务深度合成管理规定(征求意见稿),并向社会公开征求意见。其中规定深度合成服务使用者必须进行真实身份信息认证,否则深度合成服务提供者不得为其提供信如何用Python编猜拳小游戏第一版之前我一直在出Python教程,现在我要再次编一个Python游戏。这次的游戏名叫猜拳小游戏,用户输入出石头,剪刀,还是布。然后让电脑随机出石头,剪刀,布。最后判断是玩家赢了还是电全通控股(08316。HK)高创远为拟以资本注入方式投资江苏普亚约10新股权格隆汇1月28日丨全通控股(08316。HK)宣布,公司的间接全资附属公司陕西高创远为能源有限公司(高创远为)于2022年1月28日,与江苏普亚能源科技有限公司(江苏普亚)订立谅解红米75吋游戏电视白菜价,HDMI2。1多项游戏认证近日京东年货节,红米L75R8X游戏电视2022款,目前活动售价仅4999元,如此神机如此好价,还不快快入手!色彩表现94DCIP3色域,E2,高色准屏幕,颜色还原真实准确。游戏性向移动端元宇宙进军?微软收购暴雪显游戏产业趋势美国华尔街日报网站近日报道称,微软以750亿美元收购动视暴雪的交易反映了推动游戏行业整合的两大趋势向移动端的推进和元宇宙的构建。美国韦德布什证券公司分析师丹艾夫斯说该交易将对其他游哪个牌子的学生平板好用又便宜?谢谢邀请。给孩子买平板,和家长说一堆软硬件知识和测评,用处不大。因为,懂这些的,不用你讲,不懂的,你讲了也还是不懂。我是一个初二孩子的家长,现在从传统媒体转型做移动互联网的产品和平联想集团斥资3亿元成立半导体公司,董事长曾表示未来三年研发投入要翻番1月28日,资本邦了解到,近日港股公司联想集团(00992。HK)斥巨资新成立一家半导体公司。天眼查显示,1月26日,鼎道智芯(上海)半导体有限公司正式成立,注册资本为3亿元人民币应届生怒怼VS腾讯企业价值观大家都关注到最近一名应届生的事,我们先来一起回顾下事情大概情况。1月25日深夜,腾讯企业微信部门的一名25岁应届生员工在内部群中发消息给管理层提建议,这一建议被同事默许并点赞,在大智能家电春节档,父母心中的智障家电今年过年回家,千万不要给父母买智能家电如果已经买了,那么请自求多福。云米智能冰箱一则消息曾登上热搜一位网友花大价钱买来的云米智能冰箱,其大屏幕一直推送购物广告信息,不管是充会员,还
工业互联网解决方案互联网经济(IndustrialInternet)是新一代信息和通讯技术与区域经济发展深度融合的新设备运用方式和行业生态体系,根据和人机物系统软件等的彻底联接,已经搭建包含全部产业那些离不开的Chrome扩展插件虽然Chrome浏览器是个吃内存的怪兽,但是,它却因为启动速度调试功能等成为了程序猿的必备浏览器!今天有时间,整理一下自己最常用的一些Chrome扩展吧常用网页浏览非开发类扩展Ta理解了状态管理,就理解了前端开发的核心状态管理是前端整天遇到的概念,但是大家是否思考过什么是状态,管理的又是什么呢?我们知道,程序是处理数据的,数据是信息的载体,比如颜色是红色或蓝色这就是数据。那为什么不叫数据管理呢?英媒印度裔高管在硅谷高歌猛进,他还打破了扎克伯格的纪录英国星期日泰晤士报网站12月4日发表题为印度裔企业高管们正在硅谷高歌猛进的文章,作者为丹尼福特森。全文摘编如下当推特网站老板杰克多尔西在这家市值340亿美元的社交媒体公司任职15年腾讯技术公益创投计划启动中证网讯(记者万宇)12月7日,在大湾区科学论坛湾区科创峰会上,腾讯技术公益创投计划宣布启动。该计划重点关注缺乏资金资助技术支援运营指导传播渠道志愿者能力的五类社会企业和公益组织,恒大终于出现转机,许家印果然不简单文北桥校对北桥其实恒大之所以会出现问题,并不是因为恒大的房产有质量问题,而是因为恒大的步子跨太大了。在此之前的恒大,又是搞粮油,又是搞旅游,甚至还搞起了新能源汽车。并且许家印做新能如何正确避开互联网项目的坑?一直在做互联网项目,已经做了8年了。互联网项目呢,坑多肉少,自己单干的话赚不了多少钱,投资吧又担心被割了韭菜,团队运营吧,也只有团队长能赚到钱,项目一跑路,团队长也不见了,这是很多建设世界科技强国需要卓越工程师进入21世纪以来,全球科技创新进入空前密集活跃的时期,新一轮科技革命和产业革命正在重构全球创新版图重塑全球经济结构。科学技术从来没有像今天这样深刻影响着国家前途命运,从来没有像今天正式获得批准,台积电新工厂确定了!外媒这是新里程碑在全球缺芯的大环境下,老美为了得到台积电先进的技术和产能,可谓是煞费苦心。老美先是修改了芯片规则,台积电答应赴美建厂也是不得已而为之。另外美方还把台积电列入了风险清单,并强行向台积要求相互宝公开已运营以来的账目明细相互宝,一款互联网不伦不类的产品,让广大网民投入了不少心血,我本人自2018年以来为家人及父母等多人购买该款产品,之所以说是不伦不类的产品,因为它既不是保险,也不是公益,时至今日相外媒脸书抹黑泄密前员工,在国会搅浑水逃避监管近期有外媒披露,美国社交媒体巨头脸书(Facebook)从今年10月泄密者豪根在电视上公开身份以来,就试图通过游说者向国会两党议员提供不同的故事,一方面回应外界批评,另一方面达到分