OpenStack API理解與應(yīng)用

OpenStack的各個(gè)服務(wù)組件都有提供相應(yīng)的API接口每聪,如nova-api,gance-api等等曲聂。使用這些 API和擴(kuò)展可以讓用戶在OpenStack云中進(jìn)行一系列的操作移宅,如啟動(dòng)服務(wù)主機(jī),創(chuàng)建鏡像共螺,給主機(jī)和鏡像設(shè)置元數(shù)據(jù),創(chuàng)建容器和對(duì)象等等情竹。

但在調(diào)用任何組件的API前藐不,必須通過Identity API進(jìn)行鑒權(quán)。

Identity Service

Identity Service 具備的功能:

??Tracking users and their permissions.

? Providing a catalog of available services with their API endpoints

開始我認(rèn)為是進(jìn)行用戶身份權(quán)限驗(yàn)證的服務(wù)秦效,但是后來發(fā)現(xiàn)它只是進(jìn)行用戶授權(quán)雏蛮。

為了方便管理,它抽象出了一組概念:

User | Credentials | Authentication | Token | Tenant | Service | Endpoint | Role | Keystone Client

具體對(duì)這些概念的說明阱州,參見

http://docs.openstack.org/juno/install-guide/install/apt/content/keystone-concepts.html

http://www.cnblogs.com/yuki-lau/archive/2013/01/04/2843918.html

下圖是一個(gè)權(quán)限驗(yàn)證的過程:

OpenStack Identity process flow

1. 用戶想要?jiǎng)?chuàng)建一個(gè)服務(wù)器挑秉。首先用戶要提供自己的認(rèn)證信息(可能是用戶名和密碼,或者是用戶名和API key)苔货,然后keystone提供一個(gè)臨時(shí)的token和一個(gè)服務(wù)列表(serviceCatalog)

2. 用戶使用臨時(shí)的token請(qǐng)求他所有的Tenant信息(可以理解為一些資源)犀概,keystone返回Tenants 列表立哑。

3. Keystone 提供用戶目標(biāo)Tenant里面的服務(wù)列表。用戶用自己的鑒權(quán)信息獲得目標(biāo)Tenant的token和服務(wù)列表姻灶,然后使用tenant token和指定服務(wù)的endpoint(可以理解為具體的API)信息去啟動(dòng)服務(wù)器铛绰。

4. 該服務(wù)去和keystone驗(yàn)證該token是否正確。

5. Keystone返回這個(gè)token的相關(guān)信息:用戶獲得鑒權(quán)被允許訪問這個(gè)服務(wù)产喉;token和這個(gè)請(qǐng)求相符至耻;token屬于這個(gè)用戶。

6. 服務(wù)執(zhí)行該請(qǐng)求(創(chuàng)建服務(wù)器)镊叁。

7. 執(zhí)行完成后返回結(jié)果尘颓。

OpenStack中調(diào)用任何API,在執(zhí)行請(qǐng)求前都要經(jīng)過keystone認(rèn)證晦譬,下圖說明了keystone和其他各個(gè)服務(wù)組件的關(guān)系:


Keystone在OpenStack中的訪問流程

API調(diào)用方式

OpenStack提供了多種API調(diào)用的方式疤苹,參見http://docs.openstack.org/api/quick-start/content/ ,有

cURL

OpenStack命令行客戶端

REST客戶端

軟件開發(fā)工具包(SDK)

Identity API

Identity API是一個(gè)ReSTful web service敛腌,是所有service APIs的入口卧土。要訪問Identity API,你必須知道它的URL和訪問方式像樊。默認(rèn)Identity的服務(wù)端口為5000尤莺,具體可以查詢keystone中對(duì)各個(gè)服務(wù)的endpoint的設(shè)置。下面介紹一些API的具體內(nèi)容

請(qǐng)求認(rèn)證并生成token的API:

method: 'POST' ? ? URL : '/v2.0/tokens'

每個(gè)ReST請(qǐng)求需要有X-Auth-Token 作為header生棍。

認(rèn)證時(shí)颤霎,需要提供user ID和密碼或者是一個(gè)token。

如果token過期涂滴,會(huì)返回一個(gè)401

如果是請(qǐng)求中的token過期友酱,會(huì)返回404

Identity將過期token視為無效token。

部署時(shí)可以指定token的過期時(shí)間

正常返回碼:200柔纵,203

錯(cuò)誤返回碼:identityFault (400, 500, …), userDisabled (403), badRequest (400), unauthorized (401), forbidden (403), badMethod (405), overLimit (413), serviceUnavailable (503), itemNotFound (404)

所有的API提供json和xml兩種格式

可以訪問http://developer.openstack.org/api-ref.html 官方文檔獲取更具體的內(nèi)容缔杉。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市搁料,隨后出現(xiàn)的幾起案子或详,更是在濱河造成了極大的恐慌,老刑警劉巖郭计,帶你破解...
    沈念sama閱讀 212,383評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件霸琴,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡拣宏,警方通過查閱死者的電腦和手機(jī)沈贝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門杠人,熙熙樓的掌柜王于貴愁眉苦臉地迎上來勋乾,“玉大人宋下,你說我怎么就攤上這事〖” “怎么了学歧?”我有些...
    開封第一講書人閱讀 157,852評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長各吨。 經(jīng)常有香客問我枝笨,道長,這世上最難降的妖魔是什么揭蜒? 我笑而不...
    開封第一講書人閱讀 56,621評(píng)論 1 284
  • 正文 為了忘掉前任横浑,我火速辦了婚禮,結(jié)果婚禮上屉更,老公的妹妹穿的比我還像新娘徙融。我一直安慰自己,他們只是感情好瑰谜,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,741評(píng)論 6 386
  • 文/花漫 我一把揭開白布欺冀。 她就那樣靜靜地躺著,像睡著了一般萨脑。 火紅的嫁衣襯著肌膚如雪隐轩。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,929評(píng)論 1 290
  • 那天渤早,我揣著相機(jī)與錄音职车,去河邊找鬼。 笑死鹊杖,一個(gè)胖子當(dāng)著我的面吹牛提鸟,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播仅淑,決...
    沈念sama閱讀 39,076評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼称勋,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了涯竟?” 一聲冷哼從身側(cè)響起赡鲜,我...
    開封第一講書人閱讀 37,803評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎庐船,沒想到半個(gè)月后银酬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,265評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡筐钟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,582評(píng)論 2 327
  • 正文 我和宋清朗相戀三年揩瞪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片篓冲。...
    茶點(diǎn)故事閱讀 38,716評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡李破,死狀恐怖宠哄,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情嗤攻,我是刑警寧澤毛嫉,帶...
    沈念sama閱讀 34,395評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站妇菱,受9級(jí)特大地震影響承粤,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜闯团,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,039評(píng)論 3 316
  • 文/蒙蒙 一辛臊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧房交,春花似錦浪讳、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至负溪,卻和暖如春透揣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背川抡。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評(píng)論 1 266
  • 我被黑心中介騙來泰國打工辐真, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人崖堤。 一個(gè)月前我還...
    沈念sama閱讀 46,488評(píng)論 2 361
  • 正文 我出身青樓侍咱,卻偏偏與公主長得像,于是被迫代替她去往敵國和親密幔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子楔脯,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,612評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容

  • Openstack Mitaka安裝部署教程 一、實(shí)驗(yàn)環(huán)境: 系統(tǒng):centos7.2-minimal 網(wǎng)絡(luò):管理...
    指間_流年閱讀 2,190評(píng)論 0 0
  • 第一章 OpenStack基礎(chǔ) OpenStack管理的資源及提供的服務(wù)OpenStack做為一個(gè)操作系統(tǒng)胯甩,...
    sgt_tiger閱讀 12,900評(píng)論 4 72
  • 3.1 CentOS7的時(shí)間同步服務(wù)器chrony 下載chrony 1[root@linux-node1 ~]#...
    mark_meng閱讀 4,238評(píng)論 1 0
  • 我總不問歸期 因?yàn)闅w期是給急于回去的人準(zhǔn)備的 我不問 好像離開的日子還很長 我不問 好像忘了時(shí)間有腳 而當(dāng)離別只剩...
    采棠煨酒閱讀 224評(píng)論 0 4
  • 在上篇文章中昧廷,我對(duì)唯品會(huì)app做了個(gè)大致的分析,畢竟那是第一篇偎箫,有很多不太完美的地方木柬。不過還是收到了一些喜歡和評(píng)論...
    Jelly妮閱讀 6,890評(píng)論 3 11