k8s之身份認證與權限

Kubernetes 中提供了良好的多租戶認證管理機制,如 RBAC、ServiceAccount 還有各種策略等。


通過該文件可以看到已經配置了 RBAC 訪問控制
/usr/lib/systemd/system/kube-apiserver.service


1.1 認證

所有 Kubernetes 集群有兩類用戶:由 Kubernetes 管理的Service Accounts (服務賬戶)和(Users Accounts) 普通賬戶。普通賬戶是假定被外部或獨立服務管理的,由管理員分配 keys,用戶像使用 Keystone 或 google 賬號一樣,被存儲在包含 usernames 和 passwords 的 list 的文件里。需要注意:在 Kubernetes 中不能通過 API 調用將普通用戶添加到集群中。
普通帳戶是針對(人)用戶的,服務賬戶針對 Pod 進程。
普通帳戶是全局性。在集群所有namespaces中,名稱具有唯一性。
通常,群集的普通帳戶可以與企業數據庫同步,新的普通帳戶創建需要特殊權限。服務賬戶創建目的是更輕量化,允許集群用戶為特定任務創建服務賬戶。
普通帳戶和服務賬戶的審核注意事項不同。
對于復雜系統的配置包,可以包括對該系統的各種組件的服務賬戶的定義。


1.1.1 Service Account 自動化

1.1.1.1?Service Account Admission Controller

通過 Admission Controller 插件來實現對 pod 修改,它是 apiserver 的一部分。創建或更新 pod 時會同步進行修改 pod。
當插件處于激活狀態(在大多數發行版中都默認情況)創建或修改 pod 時,會按以下操作執行:如果 pod 沒有設置 ServiceAccount,則將 ServiceAccount 設置為 default。
確保 pod 引用的 ServiceAccount 存在,否則將會拒絕請求。
如果 pod 不包含任何 ImagePullSecrets,則將ServiceAccount 的 ImagePullSecrets 會添加到 pod 中。
為包含 API 訪問的 Token 的 pod 添加了一個 volume。把 volumeSource 添加到安裝在 pod 的每個容器中,掛載在 /var/run/secrets/kubernetes.io/serviceaccount。

1.1.1.2?Token Controller

TokenController 作為 controller-manager 的一部分運行。異步行為:觀察 serviceAccount 的創建,并創建一個相應的 Secret 來允許 API 訪問。
觀察 serviceAccount 的刪除,并刪除所有相應的ServiceAccountToken Secret
觀察 secret 添加,并確保關聯的 ServiceAccount 存在,并在需要時向 secret 中添加一個 Token。
觀察 secret 刪除,并在需要時對應 ServiceAccount 的關聯

1.1.1.3?Service Account Controller

Service Account Controller 在 namespaces 里管理ServiceAccount
并確保每個有效的 namespaces 中都存在一個名為 “default” 的 ServiceAccount。

2??授權(RBAC)

2.1?Role

代表一個角色,會包含一組權限,沒有拒絕規則,只是附加允許。它是 Namespace 級別的資源,只能作用與 Namespace 之內。# 查看已有的角色信息
kubectl get role -n ingress-nginx -oyamlyaml配置文件:apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:labels:app.kubernetes.io/name: ingress-nginxapp.kubernetes.io/part-of: ingress-nginxname: nginx-ingressnamespace: ingress-nginx
roles:
- apiGroups:- ""resources:- configmaps- pods- secrets- namespacesverbs:- get
- apiGroups:- ""resourceNames:- ingress-controller-label-nginxresources:- configmapsverbs:- get- update
- apiGroups:- ""resources:- configmapsverbs:- create

2.2?ClusterRole

功能與 Role 一樣,區別是資源類型為集群類型,而 Role 只在 Namespace# 查看某個集群角色的信息
kubectl get clusterrole view -oyaml

2.3?RoleBinding

Role 或 ClusterRole 只是用于制定權限集合,具體作用與什么對象上,需要使用 RoleBinding 來進行綁定。作用于 Namespace 內,可以將 Role 或 ClusterRole 綁定到 User、Group、Service Account 上。# 查看 rolebinding 信息
kubectl get rolebinding --all-namespaces# 查看指定 rolebinding 的配置信息
kubectl get rolebinding <role_binding_name> --all-namespaces -oyamlyaml配置文件:apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:......
roleRef:apiGroup: rbac.authorization.k8s.iokind: Rolename nginx-ingress-role
subjects:
- kind: ServiceAccountname: nginx-ingress-serviceaccountnamespace: ingress-nginx

2.4?ClusterRoleBinding

與 RoleBinding 相同,但是作用于集群之上,可以綁定到該集群下的任意 User、Group 或 Service Account

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/215343.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/215343.shtml
英文地址,請注明出處:http://en.pswp.cn/news/215343.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

mysql數據庫學習筆記(1)

今天開始學mysql數據庫&#xff0c;為什么要學這個呢&#xff0c;因為數據庫可結構化存儲大量的數據信息&#xff0c;方便用戶進行有效的檢索和訪問。數據庫可有效地保持數據信息的一致性、完整性、降低數據冗余。數據庫可滿足應用的共享和安全方面的要求&#xff0c;把數據放在…

java--認識異常、自定義異常

1.異常體系 Error&#xff1a;代表的系統級別錯誤(屬于嚴重問題)&#xff0c;也就是說系統一旦出現問題&#xff0c;sun公司會把這些問題封裝成Error對象給出來&#xff0c;說白了&#xff0c;Error是給sun公司自己用的&#xff0c;不是給我們程序員用的&#xff0c;因此我們開…

MacOS下homebrew的安裝與使用

安裝Homebrew //刪除原來的文件&#xff0c;可以在刪除前查看下Cellar文件夾下已安裝的包,homebrew將工具安裝在這個文件夾下&#xff0c;并在/usr/local/bin下建立連接 sudo -irm -rf /usr/local/Cellar /usr/local/.gi sudo chown -R liudong /usr/local //更新文件屬主為liu…

114. 二叉樹展開為鏈表 --力扣 --JAVA

題目 給你二叉樹的根結點 root &#xff0c;請你將它展開為一個單鏈表&#xff1a; 展開后的單鏈表應該同樣使用 TreeNode &#xff0c;其中 right 子指針指向鏈表中下一個結點&#xff0c;而左子指針始終為 null 。展開后的單鏈表應該與二叉樹 先序遍歷 順序相同。 解題思路 …

通過Ai幫我們寫前端界面設計

現在我要寫一個前端界面&#xff0c;from表單&#xff0c;讓用戶登錄使用的&#xff0c;提交表單之前先分析用戶名和密碼是否填的完成&#xff0c;并且檢查密碼必須滿足 包含大小寫&#xff0c;數字&#xff0c;密碼長度必須在8到20之間&#xff0c;不滿足不可以提交。用戶名必…

ethtool

ethtool ethtool是一個常用的命令行工具&#xff0c;用于配置和查詢以太網接口的驅動程序和硬件參數。它提供了一種簡單的方式來檢查和修改網絡接口的設置&#xff0c;以及獲取與以太網接口相關的統計數據和狀態信息。 ethtool可以執行以下常見的操作&#xff1a; 查詢接口信息…

【Hadoop】修改YARN配置文件

本節需要修改的 YARN 配置文件保存在$HADOOP_HOME/etc/haoop 目錄下&#xff0c;需要修改的文件共有 7 個&#xff0c;分別是&#xff1a;core-site.xml, hadoop-env.sh, hdfs-site.xml, yarn-site.xml, yarn-env.sh, mapred-site.xml, slave. 這些文件的用途&#xff1a; core…

Mysql:慢cpu過高慢sql查詢方法

通過 processlist查詢較為便捷&#xff0c;只是結果的info中只會顯示sql的前100個字符。 show processlist 通過下面語句查詢可顯示當前正在執行的完整sql。 SELECT * FROM information_schema.processlist WHERE COMMAND ‘Query’; 借助navicate數據庫工具的監控功能查詢庫的…

大數據技術2:大數據處理流程

前言&#xff1a;下圖是一個簡化的大數據處理流程圖&#xff0c;大數據處理的主要流程包括數據收集、數據存儲、數據處理、數據應用等主要環節。 1.1 數據收集 大數據處理的第一步是數據的收集。現在的中大型項目通常采用微服務架構進行分布式部署&#xff0c;所以數據的采集需…

【常用字符大全】含emoji表情

常用符號大全 ?????????????▲???↑↓◆◇⊙■□△▽─│??♂♀?????????▼???≈←→?◎☉★☆⊿※¡━┃??ツ?????©?Σ????卐√↖↗●?Θ◤◥︻〖〗┄┆℃℉?????¢€£∞?★?↙↘○?⊕◣◢︼【】┅┇…

Java 中適合使用隊列(Queue)的場景

在 Java 中&#xff0c;隊列&#xff08;Queue&#xff09;適合用于以下場景&#xff1a; 先進先出&#xff08;FIFO&#xff09;數據處理&#xff1a;當需要按照數據的添加順序進行處理時&#xff0c;可以使用隊列。例如&#xff0c;處理任務隊列、消息隊列等。 示例&#xff…

MySQL慢SQL優化思路

MySQL慢SQL優化思路 具體思路&#xff1a; 1、慢查詢日志記錄慢 SQL 2、explain 分析 SQL 的執行計劃 3、profile 分析執行耗時 4、Optimizer Trace 分析詳情 5、確定問題并采用相應的措施 1、查看慢日志 1.1 使用命令查詢慢日志配置 mysql> show variables like s…

mysql 5.7.34升級到5.7.44修補漏洞

mysql 5.7.34舊版本&#xff0c;漏掃有漏洞&#xff0c;升級到最新版本 舊版本5.7.34在 /home/mysql/mysql中安裝 備份舊版本數據還有目錄 數據庫備份升級 tar -xf mysql-5.7.44-el7-x86_64.tar #覆蓋舊版本數據庫文件 #注意看看文件是否和你起服務的用戶一樣 \cp -r mysql-5…

decomposition-based multi-objective algorithm4SPDPTW

關鍵詞 文章概述 研究背景 多目標選擇性接送和配送問題&#xff08;PDPs&#xff09;&#xff1a;研究涉及多目標選擇性接送和配送問題&#xff0c;這些問題傳統上從單一目標角度進行探討&#xff0c;以尋找最具盈利性的請求集合&#xff0c;同時遵守一系列限制條件。 經濟和…

基于OpenCV+CNN+IOT+微信小程序智能果實采摘指導系統——深度學習算法應用(含python、JS工程源碼)+數據集+模型(五)

目錄 前言總體設計系統整體結構圖系統流程圖 運行環境Python環境TensorFlow 環境Jupyter Notebook環境Pycharm 環境微信開發者工具OneNET云平臺 模塊實現1. 數據預處理2. 創建模型并編譯3. 模型訓練及保存4. 上傳結果5. 小程序開發1&#xff09;查詢圖片2&#xff09;查詢識別結…

?os.path --- 常用路徑操作?

源代碼: Lib/posixpath.py (用于 POSIX) 和 Lib/ntpath.py (用于 Windows)。 此模塊實現了一些有用的路徑名稱相關函數。 要讀取或寫入文件請參見 open()&#xff0c;對于訪問文件系統請參閱 os 模塊。 傳給 path 形參的可以是字符串、字節串或者任何實現了 os.PathLike 協議的…

【收獲】成長之路

目錄 一、前言二、計算機方面三、專業知識方面四、總結 一、前言 四年&#xff0c;對于一個人的成長來說&#xff0c;是一個相當重要的階段。在這段時間里&#xff0c;我經歷了許多挑戰、收獲了許多成就&#xff0c;也在不斷地成長和改變。回首這四年的點點滴滴&#xff0c;我深…

hasattr( )函數的用法

hasattr() 函數用于檢查一個對象是否具有指定的屬性或方法&#xff0c; 它接受兩個參數&#xff1a;對象和屬性名&#xff08;或方法名&#xff09; 函數語法如下&#xff1a; hasattr(object, attribute)參數說明&#xff1a; object&#xff1a;要檢查的對象attribute&…

前端Vue面試題總結

1,Vue組件的生命周期有哪些,它們的執行順序是什么? Vue組件的生命周期包括beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy和destroyed等。它們的執行順序如下:beforeCreate -> created -> beforeMount -> mounted -> be…

安裝LLaMA-Factory微調chatglm3,修改自我認知

安裝git clone https://github.com/hiyouga/LLaMA-Factory.git conda create -n llama_factory python3.10 conda activate llama_factory cd LLaMA-Factory pip install -r requirements.txt 之后運行 CUDA_VISIBLE_DEVICES0 python src/train_web.py&#xff0c;按如下配置…