OpenStack Identity(Keystone)身份服務(wù)、體系結(jié)構(gòu)與中間件講解
OpenStack Identity(Keystone)服務(wù)為運行OpenStack Compute上的OpenStack云提供了認(rèn)證和管理用戶、帳號和角色信息服務(wù),并為OpenStack Object Storage提供授權(quán)服務(wù)。
Keystone體系結(jié)構(gòu)
Keystone 有兩個主要部件:驗證和服務(wù)目錄
驗證:提供了一個基于令牌的驗證服務(wù),主要有以下幾個概念:
租戶(Tenant)
使用OpenStack相關(guān)服務(wù)的一個組織。一個租戶映射到一個Nova的“project-id”,在對象存儲中,一個租戶可以有多個容器。根據(jù)不同的安裝方式,一個租戶可以代表一個客戶、帳號、組織或項目。
用戶(User)
代表一個個體,OpenStack以用戶的形式來授權(quán)服務(wù)給它們。用戶擁有證書(credentials),且可能分配給一個或多個租戶。經(jīng)過驗證后,會為每個單獨的租戶提供一個特定的令牌。
證書(credentials)
為了給用戶提供一個令牌,需要用證書來唯一標(biāo)識一個Keystone用戶的密碼或其它信息
令牌(token)
一個令牌是一個任意比特的文本,用于與其它OpenStack服務(wù)來共享信息,Keystone以此來提供一個central location,以驗證訪問OpenStack服務(wù)的用戶。一個令牌可以是“scoped”或“unscoped”。一個scoped令牌代表為某個租戶驗證過的用戶,而unscoped令牌則僅代表一個用戶。令牌的有效期是有限的,可以隨時被撤回。
角色(Role)
一個角色是應(yīng)用于某個租戶的使用權(quán)限集合,以允許某個指定用戶訪問或使用特定操作。角色是使用權(quán)限的邏輯分組,它使得通用的權(quán)限可以簡單地分組并綁定到與某個指定租戶相關(guān)的用戶。
服務(wù)目錄(Service Catalog)
Keystone為OpenStack安裝提供了一個REST API端點列表并以此作為決策參考。主要的概念包括:
服務(wù)(Service)
一個OpenStack服務(wù),例如nova、swift、glance或keystone。一個服務(wù)可以擁有一個或多個端點,通過它用戶可以與OpenStack的服務(wù)或資源交互。
端點(Endpoint)
一個可以通過網(wǎng)絡(luò)訪問的地址(典型地,一個URL),代表了OpenStack服務(wù)的API接口。端點也可以分組為模板,每個模板代表一組可用的OpenStack服務(wù),這些服務(wù)是跨區(qū)域(regions)可用的。
模板(Template)
一個端點集合,代表一組可用的OpenStack服務(wù)端點。
Keystone的組件
Keystone包含一個命令行接口,可以與Keystone API交互以管理keystone和相關(guān)服務(wù)。
keystone - 運行keystone-admin和keystone-service
keystone-admin - 操作keystone的管理API
keystone-service - 用于驗證的,面向用戶的AP
keystone-manage - 管理keystone的命令行接口
Keystone還包括WSGI中間件以為Nova和Swift提供驗證服務(wù)。
Keystone使用一個內(nèi)置的SQLite數(shù)據(jù)庫 - 為驗證用戶,將來也可能使用一個外部LDAP服務(wù)來代替存儲證書
中間件(Middleware)
Keystone中間件位于OpenStack服務(wù)前面,處理進(jìn)來的請求驗證。中間件的設(shè)計遵循如下的規(guī)范。
中間件的源代碼位于Keystone/middleware。
中間件支持兩個接口:WSGI和REST/HTTP。
REST & HTTP API
如果進(jìn)來一個未經(jīng)認(rèn)證的調(diào)用,中間件將響應(yīng)一個401 Unautorized錯誤。根據(jù)每HTTP的標(biāo)準(zhǔn),它也會返回一個WWW-Authenticate包頭以通知調(diào)用者支持哪個協(xié)議。對于Keystone驗證,響應(yīng)的語法格式如下:
WWW-Authenticate: Keystone uri="url to Keystone server"The client can then make the necessary calls to the Keystone server, obtain a token, and retry the call with the token.
令牌使用 X-Auth-Toke包頭傳遞。
WSGI API(包頭)
當(dāng)成功驗證后中間件經(jīng)為下行的WSGI應(yīng)用發(fā)送如下包頭:
X-Identity-Status
提供請求是否被驗證的信息。
X-Tenant
提供了租戶ID(在Keystone中以URL的形式出現(xiàn))。在Keysotne轉(zhuǎn)為采用ID/Name模式之前,它為租戶提供了對任意遺留實現(xiàn)的支持。
X-Tenant-Id
唯一不變的租戶ID。
X-Tenant-Name
唯一但可變的租戶名字。
X-User
用于登錄的用戶名。
X-Roles
分配給用戶的角色。
以上所述是小編給大家介紹的OpenStack Identity(Keystone)身份服務(wù)、體系結(jié)構(gòu)與中間件 ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
詳解OpenStack云平臺的網(wǎng)絡(luò)模式及其工作機制
這篇文章主要介紹了詳解OpenStack云平臺的網(wǎng)絡(luò)模式及其工作機制,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2016-12-12OpenStack 創(chuàng)建windows鏡像實現(xiàn)步驟
這篇文章主要介紹了 OpenStack 創(chuàng)建windows鏡像實現(xiàn)步驟的相關(guān)資料,需要的朋友可以參考下2016-11-11centos下最簡安裝openstack——使用packstack詳解
本篇文章主要介紹了centos下最簡安裝openstack——使用packstack,具有一定的參考價值,有興趣的可以了解一下。2017-01-01OpenStack手動分布式部署Glance(Queens版)
這篇文章主要介紹了OpenStack手動分布式部署Glance(Queens版),Glance為云平臺虛擬機提供鏡像服務(wù),例如:上傳鏡像、刪除鏡像等,需要的朋友可以參考下2023-03-03OpenStack Mitaka 版本中的 domain 和 admin詳解
這篇文章主要介紹了OpenStack Mitaka 版本中的 domain 和 admin詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03Openstack 網(wǎng)絡(luò)知識資料詳細(xì)介紹及總結(jié)
這篇文章主要介紹了Openstack 網(wǎng)絡(luò)知識資料詳細(xì)介紹及總結(jié)的相關(guān)資料,在開發(fā)云計算的時候 Openstack 很多公司都在用,這里就整理下網(wǎng)絡(luò)知識,需要的朋友可以參考下2016-12-12Openstack 節(jié)點維護(hù)詳細(xì)講解
這篇文章主要介紹了Openstack 節(jié)點維護(hù)詳細(xì)講解的相關(guān)資料,需要的朋友可以參考下2016-11-11