主頁 > 軟體設計 > OpenStack的探索之路——基礎理論精講篇

OpenStack的探索之路——基礎理論精講篇

2020-12-11 16:46:29 軟體設計

前言:

openstack是一個開源的云計算管理平臺架構,是一系列開源的軟體專案的組合,由NASA(美國國家航空航天局)和Rackspace合作研發并發起,以Apache許可證(Apache軟體基金會發布的一個自由軟體許可證)授權的開源代碼專案,

它為私有云和公有云的建設與管理提供了開源軟體專案,在傳統的運維管理服務器資源的基礎上,有了openstack架構之后,才可在其之上部署云平臺的服務,進行運維和管理,

一、云計算概述

1.1 云計算概念

云計算管理的是網路資源、存盤資源、服務器資源等物理硬體資源,可以使客戶在任何時間任何地點,通過網路,獲取所需要的資源或服務,并且按需分配,按用量進行收費,

1.2 云計算服務型別

1.2.1 IAAS(基礎架構即服務)

提供底層IT基礎設施服務,包括處理能力,存盤空間、網路資源,一般面對物件是IT管理人員,

用戶可獲取的是硬體或虛擬硬體,包括裸機或虛擬機,可以自行安裝作業系統或其他應用程式,

1.2.2 PAAS(平臺即服務)

把安裝好開發環境的系統平臺作為一種服務通過互聯網提供給用戶,一般面對物件是開發人員,

用戶可獲取的是安裝了作業系統以及支撐應用程式運行所需要的資源庫等軟體的物理機或虛擬機,可以自行安裝其他應用程式,但不能修改已經預裝好的作業系統和運行環境,

1.2.3 SAAS(軟體即服務)

直接通過互聯網為用戶提供部署好的軟體和應用程式的服務,可直接使用,一般面向物件是普通用戶,

用戶可獲取的是以租賃的方式來直接使用一些軟體,而不是購買,

二、OpenStack 介紹

2.1 OpenStack的特性

OpenStack優勢

  • 控制性
    完全開源的平臺,提供API介面,方便與第三方技術集成
  • 兼容性
    OpenStack兼容其他公有云,方便用戶進行資料遷移
  • 可擴展性
    模塊化設計,可以通過橫向擴展,增加節點、添加資源
  • 靈活性
    根據自己的需要建立相應基礎設施、增加集群規模
    激活
  • 行業標準
    眾多IT領軍企業已經加入到OpenStack專案

2.2 OpenStack的核心組件

整個OpenStack架構由多個子服務組成:以下是幾個核心專案

服務專案描述
Compute 計算服務Nova負責實體生命周期的管理,計算資源的單位,對Hypervisor進行屏蔽,支持多種虛擬化技術(紅帽默認為KVM),支持橫向擴展
Network 網路服務Neutron負責虛擬網路的管理,為實體創建網路的拓撲結構,是面向租戶的網路管理,可以自己定義自己的網路,各個租戶之間互不影響
Identify 身份認證服務Keystone類似于LDAP服務,對用戶、租戶和角色、服務進行認證與授權,且支持多認證機制
Dashboard 控制面板服務Horizon提供一個Web管理界面,與OpenStack底層服務進行互動
Image Service 鏡像服務Glance提供虛擬機鏡像模板的注冊與管理,將做好的作業系統拷貝為鏡像模板,在創建虛擬機時直接使用,可支持多格式的鏡像
Block Storage 塊存盤服務Cinder負責為運行實體提供持久的塊存盤設備,可進行方便的擴展,按需付費,支持多種后端存盤
Object Storage 物件存盤服務Swift為OpenStack提供基于云的彈性存盤,支持集群無單點故障
Telemetry 計量服務Ceilometer用于度量、監控和控制資料資源的集中來源,為OpenStack用戶提供記賬途徑

三、OpenStack 架構

學習Openstack的部署和運維之前,應當熟悉其架構和運行機制,OpenStack作為開源、可擴展、富有彈性的云作業系統,其設計基本原則如下:
■按照不同的功能和通用性劃分不同專案,拆分子系統
■按照邏輯計劃、規范字系統之間的通信
■通過分層設計整個系統架構
■不同的功能子系統間提供統一的API介面

3.1 OpenStack 概念架構

如下圖所示:
在這里插入圖片描述

上圖的核心為虛擬機,所有組件圍繞虛擬機,為它提供服務,可將上圖的架構分為三個部分:

①藍色方框為全域組件
keystone:為所有服務模塊提供認證與授權
ceilometer:度量、監控所有資料資源
horizon :UI平臺管理,提供一個web管理頁面,與底層互動

②紅色方框為外部輔助組件
ironic 提供裸金屬環境
trove 提供管理資料庫服務(控制關系型和非關系型資料庫)
heat,sahara 提供對資料管理和編排

③黃色方框為內部核心組件
glance:提供鏡像服務
neutron:提供網路服務
swift:提供物件存盤資源
cinder:提供快存盤資源
nova:管理實體的生命周期,并負責調取以上四個資源給虛擬機使用,

具體流程:
云平臺用戶在經過Keystone服務認證授權后,通過Horizon或者Reset API模式創建虛擬機服務,創建程序中包括利用Nova服務創建虛擬機實體,虛擬機實體采用Glance提供鏡像服務,然后使用Neutron為新建的虛擬機分配IP地址,并將其納入虛擬網路中,之后在通過Cinder創建的卷為虛擬機掛載存盤塊,整個程序都在Ceilometer模塊資源的監控下,Cinder產生的卷(Volume)和Glance提供的鏡像(Image) 可以通過Swift的物件存盤機制進行保存,

3.2 OpenStack 邏輯架構

如下圖:
在這里插入圖片描述

  • 全域架構來看:OpenStack包括相互獨立的服務組件,所有服務均可通過一個公共身份服務進行身份驗證,除了那些需要管理權限的命令,每個服務之間均可通過公共API進行互動,所以,API即是每個服務內部和外部的交界處,隔離了內外,
  • 服務之間互動程序:每個服務又由若干組件組成,包含多個行程,每個服務至少有一個API行程,用于偵聽API請求,對這些請求進行預處理,( 預處理就是將請求暴露出來的API介面,給keystone進行認證,如果認證通過,則放入佇列等待被處理,) 然后將它們傳送到自己服務后端的其他組件,對請求進行處理,而不是API行程去處理,也就是說除了認證服務,實際作業都是由具體的行程完成的,
  • 服務內各個行程之間的通信:使用AMQP訊息代理,服務的狀態存盤在資料庫中,

訊息佇列:常用的三種型別,包括rabbitmq、 rocketmq、kafka,是兩個獨立的服務之間,訊息傳遞的載體,解決訊息在傳輸是請求的高并發問題,會以容器的方式,存盤訊息串列(包括請求、互動、報文),劃分重要等級放入佇列中,逐個處理,處理完的會自動洗掉,

OpenStack組件通信關系

■基于AMQP協議的通信
用于每個專案內部各個組件之間的通信,
■基于SQL的通信
用于各個專案內部的資料庫通信,
■基于HTTP協議進行通信
通過各專案的API建立的通信關系,API都是RESTful Web API,
■通過Native API實作通信
OpenStack各組件和第三方軟硬體之間的通信,

四、OpenStack 的節點

物理架構可以從四個節點來看,包括控制節點,網路節點,計算節點,存盤節點,

4.1 控制節點

定位:運維人員通過控制節點從而控制整個openstack架構,
在這里插入圖片描述

如上圖所示:控制節點包括支持服務,基礎服務,擴展服務和網路介面服務,外部的裸金屬服務提供物理資源支撐,

  • 支持服務:包括資料庫支持和通信支持,為整個節點提供資料存盤服務和服務之間訊息佇列的通信服務,
  • 基礎服務:為虛擬機提供基礎的鏡像、網路、計算資源;keystone負責整個架構的認證和授權,運維人員通過horizon可視化的界面進行管理,
  • 擴展服務:主要針對虛擬機的資料管理,heat進行資料的編排和管理,計量服務在此獲取虛擬機的資料源,進行資源監控和計量,并記錄,
  • 網路介面:專門管理節點的網路服務,用于聯系控制其他節點,

4.2 網路節點

網路節點:只有一個基礎服務,Neutron網路服務,負責整個openstack架構的網路通信,
整個網路介面又可分為管理網路、資料網路、外部網路,管理網路負責關聯其他節點的網路,讓控制節點可管控其他節點的網路,資料網路負責整個架構的資料通信,外部網路負責架構與外部物理網路的連接通信,

4.3 計算節點

計算節點包括基礎服務、擴展服務、網路介面,基礎服務有Nova Hypervisor 和網路插件代理,擴展服務為ceilometer agent 計量代理服務,網路介面為管理網路和資料網路,

4.4 存盤節點

存盤節點包括cinder和swift兩個基礎的存盤服務和網路介面,網路介面為管理網路和資料網路,

五、核心服務精講

5.1 Keystone身份認證服務

5.1.1 Keystone概念

Keystone (OpenStack Identity Service)是OpenStack中的一個獨立的提供安全認證的模塊,主要負責openstack用戶的身份認證、令牌管理、提供訪問資源的服務目錄、以及基于用戶角色的訪問控制,

Keystone類似一個服務總線,或者說是整 個Openstack框架的注冊表,其他服務通過keystone來注冊其服務的Endpoint (服務訪問的URL),任何服務之間相互的呼叫,需要經過Keystone的身 份驗證,來獲得目標服務的Endpoint來找到目標服務,

5.1.2 主要功能

  • 身份認證:負責令牌的發放和校驗
  • 用戶授權:授權用戶有指定的可執行動作的范圍
  • 用戶管理:管理用戶的賬戶
  • 服務目錄:提供可用服務的API端點位置

5.1.3 Keystone的管理物件

Keystone服務貫穿整個架構,在進行身份認證服務的整個流程中,有幾個重要的概念,

  • 用戶(user):指的是使用openstack架構的用戶,

  • 證書(credentials):用于確認用戶身份的憑證,證明自己是自己,包括用戶的用戶名和密碼,或是用戶名和API密鑰,或者身份管理服務提供的認證令牌,

  • 認證(authentication):確定用戶身份的程序,

  • 專案(project):可以理解為一個人,或服務所擁有的資源的集合,

  • 角色(role):用于劃分權限,通過給user指定role,使user獲得role對應操作權限

  • 服務(service):openstack架構的組件服務,如nova、neutron、cinder、swift、glance等,

  • 令牌(token):由字串表示,作為訪問資源的憑證,是用戶的身份/權限證明檔案;
    token決定了用戶的權限范圍,在指定的權限內進行操作;也包括令牌的有效期,在指定的時間范圍內用戶才有這些權限,

  • 端點(endpoint):一個可以通過網路來訪問和定位某個openstack service的地址,即用戶創建一個專案程序中需要的各個服務資源的位置

5.1.4 Keystone作業流程

以用戶想要通過openstack平臺創建一個虛擬機的程序為例:
在這里插入圖片描述

  • 用戶通過命令列或者horizon控制面板的方式登錄openstack,憑借自己的證書(credentials)給keystone驗證,
  • Keystone對用戶的證書驗證,驗證通過則會發布一個令牌(token)和用戶所需服務的位置點(endpoint)給用戶,
  • 用戶得到了位置點(endpoint)之后,攜帶自己的令牌,向nova發起請求,請求創建虛擬機,
  • nova會拿著用戶的token向keystone進行認證,看是否允許用戶執行這樣的操作,
  • keystone認證通過之后,回傳給nova,nova即開始執行創建虛擬機的請求,首先需要鏡像資源,nova帶著令牌(token)和所需要的鏡像名向glance提出鏡像資源的請求,
  • glance會拿著token去向keystone進行認證,看是否允許提供鏡像服務,keystone認證成功后,回傳給glance,glance向nova提供鏡像服務,
  • 創建虛擬機還需要網路服務,nova攜帶token向neutron發送網路服務的請求
  • neutron拿著nova給的token向keystone進行認證,看是否允許向其提供網路服務,keystone認證成功后,回傳給nuetron,nuetron則給nova提供網路規劃服務,
  • nova獲取了鏡像和網路之后,開始創建虛擬機,通過hypervisior可呼叫底層硬體資源進行創建,創建完成回傳給用戶,成功執行了用戶的請求,

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/233172.html

標籤:其他

上一篇:git常用命令(linux以ubuntu為例子)以及github遠程倉庫使用--初學版

下一篇:Lua編程入門(一)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more