公司主營(yíng)業(yè)務(wù):做網(wǎng)站、成都做網(wǎng)站、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)推出大名免費(fèi)做網(wǎng)站回饋大家。
本節(jié)開(kāi)始,我們將詳細(xì)講解 Nova 的各個(gè)子服務(wù)。
前面架構(gòu)概覽一節(jié)知道 Nova 有若干 nova-* 的子服務(wù),下面我們將依次學(xué)習(xí)最重要的幾個(gè)。
今天先討論 nova-api 和 nova-conductor。
Nova-api 是整個(gè) Nova 組件的門戶,所有對(duì) Nova 的請(qǐng)求都首先由 nova-api 處理。 Nova-api 向外界暴露若干 HTTP REST API 接口。 在 keystone 中我們可以查詢 nova-api 的 endponits。
客戶端就可以將請(qǐng)求發(fā)送到 endponits 指定的地址,向 nova-api 請(qǐng)求操作。 當(dāng)然,作為最終用戶的我們不會(huì)直接發(fā)送 Rest AP I請(qǐng)求。 OpenStack CLI,Dashboard 和其他需要跟 Nova 交換的組件會(huì)使用這些 API。
Nova-api 對(duì)接收到的 HTTP API 請(qǐng)求會(huì)做如下處理: 1. 檢查客戶端傳人的參數(shù)是否合法有效 2. 調(diào)用 Nova 其他子服務(wù)的處理客戶端 HTTP 請(qǐng)求 3. 格式化 Nova 其他子服務(wù)返回的結(jié)果并返回給客戶端
nova-api 接收哪些請(qǐng)求? 簡(jiǎn)單的說(shuō),只要是跟虛擬機(jī)生命周期相關(guān)的操作,nova-api 都可以響應(yīng)。 大部分操作都可以在 Dashboard 上找到。
打開(kāi)Instance管理界面
點(diǎn)擊下拉箭頭,列表中就是 nova-api 可執(zhí)行的操作。
OpenStack 用術(shù)語(yǔ) “Instacne” 來(lái)表示虛擬機(jī),后面我們將統(tǒng)一使用這個(gè)術(shù)語(yǔ)。
nova-compute 需要獲取和更新數(shù)據(jù)庫(kù)中 instance 的信息。 但 nova-compute 并不會(huì)直接訪問(wèn)數(shù)據(jù)庫(kù),而是通過(guò) nova-conductor 實(shí)現(xiàn)數(shù)據(jù)的訪問(wèn)。
這樣做有兩個(gè)顯著好處:
更高的系統(tǒng)安全性
更好的系統(tǒng)伸縮性
在 OpenStack 的早期版本中,nova-compute 可以直接訪問(wèn)數(shù)據(jù)庫(kù),但這樣存在非常大的安全隱患。 因?yàn)?nova-compute 這個(gè)服務(wù)是部署在計(jì)算節(jié)點(diǎn)上的,為了能夠訪問(wèn)控制節(jié)點(diǎn)上的數(shù)據(jù)庫(kù),就必須在計(jì)算節(jié)點(diǎn)的 /etc/nova/nova.conf 中配置訪問(wèn)數(shù)據(jù)庫(kù)的連接信息,比如
[database] connection = MySQL+pymysql://root:secret@controller/nova?charset=utf8
試想任意一個(gè)計(jì)算節(jié)點(diǎn)被******,都會(huì)導(dǎo)致部署在控制節(jié)點(diǎn)上的數(shù)據(jù)庫(kù)面臨極大風(fēng)險(xiǎn)。
為了解決這個(gè)問(wèn)題,從 G 版本開(kāi)始,Nova 引入了一個(gè)新服務(wù) nova-conductor,將 nova-compute 訪問(wèn)數(shù)據(jù)庫(kù)的全部操作都放到 nova-conductor 中,而且 nova-conductor 是部署在控制節(jié)點(diǎn)上的。 這樣就避免了 nova-compute 直接訪問(wèn)數(shù)據(jù)庫(kù),增加了系統(tǒng)的安全性。
nova-conductor 將 nova-compute 與數(shù)據(jù)庫(kù)解耦之后還帶來(lái)另一個(gè)好處:提高了 nova 的伸縮性。
nova-compute 與 conductor 是通過(guò)消息中間件交互的。
這種松散的架構(gòu)允許配置多個(gè) nova-conductor 實(shí)例。
在一個(gè)大規(guī)模的 OpenStack 部署環(huán)境里,管理員可以通過(guò)增加 nova-conductor 的數(shù)量來(lái)應(yīng)對(duì)日益增長(zhǎng)的計(jì)算節(jié)點(diǎn)對(duì)數(shù)據(jù)庫(kù)的訪問(wèn)。
下一節(jié)我們討論計(jì)算節(jié)點(diǎn)調(diào)度服務(wù) nova-scheduler.