欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

OpenStack 工作流workflows使用原理詳細(xì)介紹

 更新時間:2016年11月24日 08:49:47   投稿:lqh  
這篇文章主要介紹了OpenStack 工作流workflows使用原理詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下

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"] 



感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • openstack云計(jì)算cinder架構(gòu)及各組件功能介紹

    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ò)

    這篇文章主要介紹了淺談openstack中使用linux_bridge實(shí)現(xiàn)vxlan網(wǎng)絡(luò),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題

    OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題

    這篇文章主要介紹了OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題的相關(guān)資料,Ceilometer使用MongoDB作為數(shù)據(jù)庫,不斷進(jìn)行采樣,導(dǎo)致數(shù)據(jù)量膨脹,占用過多的磁盤空間,這里提供解決辦法,需要的朋友可以參考下
    2016-12-12
  • Openstack 使用migrate進(jìn)行數(shù)據(jù)庫升級實(shí)現(xiàn)方案詳細(xì)介紹

    Openstack 使用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)備

    本篇文章主要介紹了詳解Openstack組件部署 — Overview和前期環(huán)境準(zhǔn)備,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • openstack pike單機(jī)一鍵安裝shell的方法

    openstack pike單機(jī)一鍵安裝shell的方法

    這篇文章主要介紹了openstack pike單機(jī)一鍵安裝shell的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • OpenStack之日志詳細(xì)介紹

    OpenStack之日志詳細(xì)介紹

    這篇文章主要介紹了 OpenStack之日志詳細(xì)介紹的相關(guān)資料,這里對日志系統(tǒng)做了詳解,需要的朋友可以參考下
    2016-11-11
  • openstack云計(jì)算組件keystone部署及操作使用技巧

    openstack云計(jì)算組件keystone部署及操作使用技巧

    這篇文章主要為大家介紹了openstack云計(jì)算組件keystone部署及操作使用技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • centos下最簡安裝openstack——使用packstack詳解

    centos下最簡安裝openstack——使用packstack詳解

    本篇文章主要介紹了centos下最簡安裝openstack——使用packstack,具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01
  • OpenStack初始化淺析

    OpenStack初始化淺析

    OpenStack是一個開源的云計(jì)算管理平臺項(xiàng)目,由幾個主要的組件組合起來完成具體工作。OpenStack支持幾乎所有類型的云環(huán)境,項(xiàng)目目標(biāo)是提供實(shí)施簡單、可大規(guī)模擴(kuò)展、豐富、標(biāo)準(zhǔn)統(tǒng)一的云計(jì)算管理平臺。
    2017-01-01

最新評論