OpenStack 工作流workflows使用原理詳細(xì)介紹
Workflows
工作流是復(fù)雜的forms(表單)和tabs,每一個workflow必須包含 Workflow,Step 和 Action
下面舉例講解workflow用法:
接下來的例子講解了數(shù)據(jù)是如何從urls、views、workflows、templates之間互相傳遞的
在 urls.py中, 定義了一個參數(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ù)來源于Workflow's Steps,且保存在context['workflow'].context列表中,我們同樣可以在template 中使用它們 return context def _get_object(self, *args, **kwargs): #url中的數(shù)據(jù)通常在self.kwargs中,我們能夠在這里加載感興趣的對象 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ì)就是一個更加復(fù)雜的django form(表單)
class ResourcesAction(workflows.Action): # 下述定義的name域值 在所有的action 方法中都可以獲取 # 假若我們期望此值能夠在其他steps或者其他workflow中使用,它必須來源于當(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對應(yīng)的step中必須建立depend on關(guān)系 # 可以self.initial['resource_class_id'] or data['resource_class_id']獲取值 # 如果我們想使用其他step中的數(shù)據(jù),那么其他step 必須contribute 數(shù)據(jù),且兩個step之間是有序的 class UpdateResources(workflows.Step): # 此處傳遞Workflow 的數(shù)據(jù)到action方法handle/clean中,action中想要使用的值,此處depends_on 必須要定義 # Workflow 的context 數(shù)據(jù)包括url中的數(shù)據(jù)以及從其他step中contributed 過來的數(shù)據(jù) depends_on = ("resource_class_id",) # 通過contributes 參數(shù),此處的數(shù)據(jù)可以被其他workflow或者其他step使用,值得注意的是,object_ids key需要手動添加到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 方法,手動添加到字典里 context["resources_object_ids"] =\ request.POST.getlist("resources_object_ids") # 合并上面?zhèn)鬟f來的數(shù)據(jù),也可以交給父類去合并 context.update(data) return context class UpdateResourceClass(workflows.Workflow): default_steps = (UpdateResources,) def handle(self, request, data): pass # 這個方法在最后執(zhí)行(所有Action的handle方法之后) # 此處可以使用step中所有'contributes=' 和'depends_on=' 的數(shù)據(jù) # 此處可以處理復(fù)雜的業(yè)務(wù)邏輯 #此處可用值: data["resources_object_ids"], data["name"] data["resources_class_id"]
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題
- OpenStack Heat AutoScaling詳解及實(shí)例代碼
- Openstack 網(wǎng)絡(luò)知識資料詳細(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ù)庫升級實(shí)現(xiàn)方案詳細(xì)介紹
相關(guān)文章
openstack云計(jì)算cinder架構(gòu)及各組件功能介紹
這篇文章主要為大家介紹了openstack云計(jì)算之cinder架構(gòu)及各組件功能介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04淺談openstack中使用linux_bridge實(shí)現(xiàn)vxlan網(wǎng)絡(luò)
這篇文章主要介紹了淺談openstack中使用linux_bridge實(shí)現(xiàn)vxlan網(wǎng)絡(luò),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題
這篇文章主要介紹了OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題的相關(guān)資料,Ceilometer使用MongoDB作為數(shù)據(jù)庫,不斷進(jìn)行采樣,導(dǎo)致數(shù)據(jù)量膨脹,占用過多的磁盤空間,這里提供解決辦法,需要的朋友可以參考下2016-12-12Openstack 使用migrate進(jìn)行數(shù)據(jù)庫升級實(shí)現(xiàn)方案詳細(xì)介紹
這篇文章主要介紹了Openstack 使用migrate進(jìn)行數(shù)據(jù)庫升級詳細(xì)介紹的相關(guān)資料,數(shù)據(jù)庫表或者增加字段等是必然的事情,如何比較容易的進(jìn)行這些數(shù)據(jù)庫升級的適配和管理,這里提供實(shí)現(xiàn)方法,需要的朋友可以參考下2016-12-12詳解Openstack組件部署 — Overview和前期環(huán)境準(zhǔn)備
本篇文章主要介紹了詳解Openstack組件部署 — Overview和前期環(huán)境準(zhǔn)備,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-03-03openstack pike單機(jī)一鍵安裝shell的方法
這篇文章主要介紹了openstack pike單機(jī)一鍵安裝shell的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03openstack云計(jì)算組件keystone部署及操作使用技巧
這篇文章主要為大家介紹了openstack云計(jì)算組件keystone部署及操作使用技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04centos下最簡安裝openstack——使用packstack詳解
本篇文章主要介紹了centos下最簡安裝openstack——使用packstack,具有一定的參考價值,有興趣的可以了解一下。2017-01-01