OpenStack 工作流workflows使用原理詳細(xì)介紹
Workflows
工作流是復(fù)雜的forms(表單)和tabs,每一個(gè)workflow必須包含 Workflow,Step 和 Action
下面舉例講解workflow用法:
接下來(lái)的例子講解了數(shù)據(jù)是如何從urls、views、workflows、templates之間互相傳遞的
在 urls.py中, 定義了一個(gè)參數(shù). 例如. resource_class_id.
RESOURCE_CLASS = r'^(?P<resource_class_id>[^/]+)/%s$' urlpatterns = patterns( '', url(RESOURCE_CLASS % 'update', UpdateView.as_view(), name='update'))
在views.py中,我們可以傳遞數(shù)據(jù)到template(模板)和action(form)中。(action 也能夠傳遞數(shù)據(jù)到get_context_data 方法或者template中)
class UpdateView(workflows.WorkflowView):
workflow_class = UpdateResourceClass
def get_context_data(self, **kwargs):
context = super(UpdateView, self).get_context_data(**kwargs)
# url中的數(shù)據(jù)通常在self.kwargs中,這里我們可以將數(shù)據(jù)傳遞給template.url
context["resource_class_id"] = self.kwargs['resource_class_id']
# 數(shù)據(jù)來(lái)源于Workflow's Steps,且保存在context['workflow'].context列表中,我們同樣可以在template 中使用它們
return context
def _get_object(self, *args, **kwargs):
#url中的數(shù)據(jù)通常在self.kwargs中,我們能夠在這里加載感興趣的對(duì)象
resource_class_id = self.kwargs['resource_class_id']
# eg:my_objects = api.nova.get_by_id(resource_class_id)
def get_initial(self):
resource_class = self._get_object()
# 此處的數(shù)據(jù)可以被Action的方法以及Workflow's handle方法使用,但是steps必須depend on該值
return {'resource_class_id': resource_class.id,
'name': resource_class.name,
'service_type': resource_class.service_type}
在workflows.py中,我們處理數(shù)據(jù),workflows本質(zhì)就是一個(gè)更加復(fù)雜的django form(表單)
class ResourcesAction(workflows.Action):
# 下述定義的name域值 在所有的action 方法中都可以獲取
# 假若我們期望此值能夠在其他steps或者其他workflow中使用,它必須來(lái)源于當(dāng)前step,且建立depend on在其他step中
name = forms.CharField(max_length=255,
label=_("Testing Name"),
help_text="",
required=True)
def handle(self, request, data):
pass
# 如果想使用url中參數(shù)值,在該Action對(duì)應(yīng)的step中必須建立depend on關(guān)系
# 可以self.initial['resource_class_id'] or data['resource_class_id']獲取值
# 如果我們想使用其他step中的數(shù)據(jù),那么其他step 必須contribute 數(shù)據(jù),且兩個(gè)step之間是有序的
class UpdateResources(workflows.Step):
# 此處傳遞Workflow 的數(shù)據(jù)到action方法handle/clean中,action中想要使用的值,此處depends_on 必須要定義
# Workflow 的context 數(shù)據(jù)包括url中的數(shù)據(jù)以及從其他step中contributed 過(guò)來(lái)的數(shù)據(jù)
depends_on = ("resource_class_id",)
# 通過(guò)contributes 參數(shù),此處的數(shù)據(jù)可以被其他workflow或者其他step使用,值得注意的是,object_ids key需要手動(dòng)添加到contributes 中
contributes = ("resources_object_ids", "name")
def contribute(self, data, context):
# 此處能獲取workflow的http request數(shù)據(jù)
request = self.workflow.request
if data:
# 只有在action中定義的數(shù)據(jù)此處才能獲取,如果想獲取其他值,則需要覆蓋contribute 方法,手動(dòng)添加到字典里
context["resources_object_ids"] =\
request.POST.getlist("resources_object_ids")
# 合并上面?zhèn)鬟f來(lái)的數(shù)據(jù),也可以交給父類去合并
context.update(data)
return context
class UpdateResourceClass(workflows.Workflow):
default_steps = (UpdateResources,)
def handle(self, request, data):
pass
# 這個(gè)方法在最后執(zhí)行(所有Action的handle方法之后)
# 此處可以使用step中所有'contributes=' 和'depends_on=' 的數(shù)據(jù)
# 此處可以處理復(fù)雜的業(yè)務(wù)邏輯
#此處可用值: data["resources_object_ids"], data["name"] data["resources_class_id"]
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- OpenStack Ceilometer用MongoDB解決占用磁盤(pán)空間過(guò)大問(wèn)題
- OpenStack Heat AutoScaling詳解及實(shí)例代碼
- Openstack 網(wǎng)絡(luò)知識(shí)資料詳細(xì)介紹及總結(jié)
- OpenStack 創(chuàng)建windows鏡像實(shí)現(xiàn)步驟
- Openstack 創(chuàng)建項(xiàng)目和虛擬機(jī)詳細(xì)介紹
- openstack 重啟的服務(wù)命令整理總結(jié)
- Openstack 節(jié)點(diǎn)維護(hù)詳細(xì)講解
- OpenStack之虛機(jī)熱遷移的代碼詳細(xì)解析
- CentOS 一鍵安裝Openstack詳細(xì)介紹
- 一步一步教你安裝openstack(圖文)
- Openstack 使用migrate進(jìn)行數(shù)據(jù)庫(kù)升級(jí)實(shí)現(xiàn)方案詳細(xì)介紹
相關(guān)文章
基于CentOS的OpenStack環(huán)境部署詳細(xì)教程(OpenStack安裝)
這篇文章主要介紹了基于CentOS的OpenStack環(huán)境部署(OpenStack安裝),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
openstack云計(jì)算組件glance部署及操作步驟
這篇文章主要為大家介紹了openstack云計(jì)算之glance部署及操作步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04
Openstack 節(jié)點(diǎn)維護(hù)詳細(xì)講解
這篇文章主要介紹了Openstack 節(jié)點(diǎn)維護(hù)詳細(xì)講解的相關(guān)資料,需要的朋友可以參考下2016-11-11
Openstack 網(wǎng)絡(luò)知識(shí)資料詳細(xì)介紹及總結(jié)
這篇文章主要介紹了Openstack 網(wǎng)絡(luò)知識(shí)資料詳細(xì)介紹及總結(jié)的相關(guān)資料,在開(kāi)發(fā)云計(jì)算的時(shí)候 Openstack 很多公司都在用,這里就整理下網(wǎng)絡(luò)知識(shí),需要的朋友可以參考下2016-12-12
openstack 虛擬機(jī)配置VIP的實(shí)現(xiàn)步驟
本文主要介紹了openstack 虛擬機(jī)配置VIP的實(shí)現(xiàn)步驟,包括查詢可用子網(wǎng)、創(chuàng)建VIP地址、綁定VIP到虛擬機(jī)端口等,具有一定的參考價(jià)值,感興趣的可以了解一下2025-01-01
簡(jiǎn)單談?wù)凮penStack中的網(wǎng)絡(luò)隔離
這篇文章主要介紹了簡(jiǎn)單談?wù)凮penStack中的網(wǎng)絡(luò)隔離的相關(guān)資料,需要的朋友可以參考下2017-03-03
CentOS 6.4下安裝部署OpenStack云計(jì)算平臺(tái)的方法
現(xiàn)在好多公司都使用Openstack,所以也想著學(xué)習(xí)下用OpenStack云計(jì)算平臺(tái),這篇文章給加詳細(xì)介紹了CentOS 6.4下安裝部署OpenStack云計(jì)算平臺(tái)的方法,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-10-10

