擴展OpenStack Dashboard簡明教程

jopen 10年前發布 | 124K 次閱讀 分布式/云計算/大數據 OpenStack

Horizon簡介

Horizon是OpenStack的一個子項目,用于提供一個Web前端控制臺(稱為Dashboard),以此來展示OpenStack的功 能。通常情況下,我們都是從Horizon、Dashboard開始來了解OpenStack的。實際上,Horizon并不會為OpenStack添加 任何一個新的功能,它只是使用了OpenStack部分API功能,因此,我們可以擴展Horizon的功能,擴展Dashboard。

擴展Dashboard

Dashboard概覽

擴展OpenStack Dashboard簡明教程

圖2-1-1 Dashboard界面

一個Dashboard(在django里稱為app)通常情況下由四個組件組成,分別為panel、tab(可選)、table和view,如圖 2-1-1所示。其中,panel、tab和table用于導航的,真正展示數據的在view里面。它們之間的關系是panel包含tab,tab包含 table,view包含table或者tab。

通過查看Horizon的源碼,可從其目錄結構看出它們之間的關系,如圖2-1-2所示。

擴展OpenStack Dashboard簡明教程

圖2-1-2 Horizon源碼目錄結構

下面,我會以在admin這個Dashboard里擴展添加一個monitoring的panel為例,介紹擴展OpenStack Dashboard的流程。

定義panel

首先介紹Dashboard.py這個文件,它位于每個Dashboard的根目錄,其作用是注冊Dashboard(django里稱為app)以及設置Dashboard的屬性,比如Dashboard里有哪些panel。

打開admin目錄下的Dashboard.py文件,設置SystemPanels有monitoring的panel:

擴展OpenStack Dashboard簡明教程

我們可以在Dashboard.py文件里隨意的添加、刪除panel屬性,這對于調試程序的時候很方便。

然后在amdin目錄下創建一個monitoring的文件夾,并在monitoring文件夾里創建panel.py文件,定義panel:

擴展OpenStack Dashboard簡明教程

這是最簡單的panel,只定義了其名字。注意:slug屬性的值要與monitoring文件夾名字一樣。當定義完成后,要記得將其注冊到Dashboard里。

定義url

Horizon是基于Django框架,程序是通過url來找到panel的,因此,需要在monitoring目錄下建立urls.py文件,定義url:

擴展OpenStack Dashboard簡明教程

定義table

table用于展示數據,Horizon提供了DataTable基類,我們可以通過繼承DataTable來實現自定義的table:

擴展OpenStack Dashboard簡明教程

在MonitoringTable里定義了兩列resources和percent。

定義view

view是用來集成table或者tab的,Horizon提供了多種vie類,下面使用DataTableView來自定義我們自己的IndexView:

擴展OpenStack Dashboard簡明教程

在IndexView里定義好table_class和template_name的屬性值,同時需要定義好get_data()方法,此方法用于獲取數據展示在table里。

至此,擴展Dashboard已完成,需要重啟apache才能看到效果:sudo service apache2 restart。效果如下:

擴展OpenStack Dashboard簡明教程

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!