You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 14 Next »

This document describes the Homing Template Specifications for residential vCPE. It is a work in progress and subject to frequent revision.

vCPE Service Model:


Homing Policies and information sources relevant to the policies:

vCPEPoliciesAndInformationSources



Homing Workflow:



SO - HAS API (R) - before retrieving homing policies

requestInfo:
  callbackUrl: https://so:5000/callback
  numSolutions: 1
  optimizer:
  - placement
  requestId: yyy-yyy-yyyy
  sourceId: so
  timeout: 600
  transactionId: xxx-xxx-xxxx
  requestType: new
placementInfo:
  orderInfo:
    requestParameters:
      customerLatitude: 32.897480
      customerLongitude: -97.040443
      customerName: some_company
  demandInfo:
    placementDemands:
    - resourceName: vGMuxInfra
      resourceId: some_resource_id
      tenantId: some_tenant_id
      resourceModelInfo:
        modelId: vGMux_model_id
        modelName: ''
        modelType: allotted
        modelVersion: '2.0'
      existingPlacement:
        serviceInstanceId: 87257b49-9602-4ca1-9817-094e52bc873b
      excludedCandidates:
      - candidateType: service
        candidates:
        - serviceInstanceId: 1ac71fb8-ad43-4e16-9459-c3f372b8236d
      requiredCandidates:
      - candidateType: service 
        candidates:
        - serviceInstanceId: 7e6c3e57-62cd-44f6-aa88-d0896998f7ec
    - resourceName: vG
      tenantId: some_tenant_id
      resourceId: 71d563e8-e714-4393-8f99-cc480144a05e
      resourceModelInfo:
        modelId: vG_model_id
        modelName: ''
        modelType: dedicated
        modelVersion: '2.0'
      existingPlacement:
        serviceInstanceId: 21d5f3e8-e714-4383-8f99-cc480144505a
      excludedCandidates:
      - candidateType: service
        candidates:
        - serviceInstanceId: 1ac71fb8-ad43-4e16-9459-c3f372b8236d
      requiredCandidates:
      - candidateType: cloud
        candidates:
        - cloud-region-id: TXAUS219

  otherInfo:
    serviceInstanceId: d61b2543-5914-4b8f-8e81-81e38575b8ec
  serviceModelInfo:
    serviceName: Residential vCPE
    service_id: vcpe_service_id
    serviceType: service
    serviceVersion: '1.0'


HAS Homing Specification (R') - after retrieving and translating homing policies

# sample homing template for vCPE 

homing_template_version: '2017-10-10'
parameters:
  service_name: Residential vCPE
  service_id: vcpe_service_id
  customer_lat: 32.897480
  customer_long: -97.040443
  REQUIRED_MEM: 4
  REQUIRED_DISK: 100
  pnf_id: some_pnf_id

# List of geographical locations
locations:
  customer_loc:
    latitude: {get_param: customer_lat}
    longitude: {get_param: customer_long}
  brg_loc:
    pnf_host_name: {get_param: pnf_id}

# List of VNFs (demands) to be homed
demands:
  vGMuxInfra:
  - inventory_provider: aai
    inventory_type: service
    attributes:
      equipment_type: vG_Mux
      customer_id: some_company
      orchestration-status: Activated
      model-invariant-id: d4da47f8-df13-4c94-9ecf-5c417bf53e27
      model-version-id: 80ca8d06-d770-4803-9186-a0f8a3091fee
    excluded_candidates:
      - candidate_id: 1ac71fb8-ad43-4e16-9459-c3f372b8236d
    existing_placement:
        - candidate_id: 21d5f3e8-e714-4383-8f99-cc480144505a
  vG:
  - inventory_provider: aai
    inventory_type: cloud

constraints:

# distance between the customer and vGMuxInfra
- constraint_vgmux_customer:
    type: distance_to_location
    demands: [vGMuxInfra]
    properties:
      distance: < 100 km
      location: customer_loc

# cloud region co-location constraint
- colocation:
    type: zone
    demands: [vGMuxInfra, vG]
    properties:
      qualifier: same
      category: region

# required HPA features, grouped by label.
# Each label corresponds to a flavor mapped by Conductor
- hpa_constraint:
    type: hpa
    demands: [vG]
    properties:
      evaluate:
      - label: flavor_label_1
        features:
        - hpa-feature: basicCapabilities
          hpa-version: v1
          hpa-hw-arch: generic
          hpa-feature-attributes:
          - hpa-attr-key: numVirtualCpu
            hpa-attr-value: "4"
            operator: "="
          - hpa-attr-key: virtualMemSize
            hpa-attr-value: "4"
            operator: "="
            unit: "GB"
        - hpa-feature: numa
          hpa-version: v1
          hpa-hw-arch: generic
          hpa-feature-attributes:
          - hpa-attr-key: numaNodes
            hpa-attr-value: "2"
            operator: "="
          - hpa-attr-key: numaCpu-0
            hpa-attr-value: [0, 1]
            operator: "="
          - hpa-attr-key: numaCpu-1
            hpa-attr-value: [2, 3, 4, 5]
            operator: "="
          - hpa-attr-key: numaMem-0
            hpa-attr-value: "2"
            operator: "="
            unit: "GB"
          - hpa-attr-key: numaMem-1
            hpa-attr-value: "4"
            operator: "="
            unit: "GB"
        - hpa-feature: cpuPinning
          hpa-version: v1
          hpa-hw-arch: generic
          hpa-feature-attributes:
          - hpa-attr-key: logicalCpuThreadPinningPolicy
            hpa-attr-value: prefer
            operator: "="
          - hpa-attr-key: logicalCpuPinningPolicy
            hpa-attr-value: dedicated
            operator: "="
      - label: flavor_label_2
        features:
          - hpa-feature: basicCapabilities
            hpa-version: v1
            hpa-hw-arch: generic
            hpa-feature-attributes:
            - hpa-attr-key: numVirtualCpu
              hpa-attr-value: "8"
              operator: "="
            - hpa-attr-key: virtualMemSize
              hpa-attr-value: "16"
              operator: "="
              unit: "GB"
          - hpa-feature: numa
            hpa-version: v1
            hpa-hw-arch: generic
            hpa-feature-attributes:
            - hpa-attr-key: numaNodes
              hpa-attr-value: "2"
              operator: "="
            - hpa-attr-key: numaCpu-0
              hpa-attr-value: [0, 1]
              operator: "="
            - hpa-attr-key: numaCpu-1
              hpa-attr-value: [2, 3, 4, 5]
              operator: "="
            - hpa-attr-key: numaMem-0
              hpa-attr-value: "2"
              operator: "="
              unit: "GB"
            - hpa-attr-key: numaMem-1
              hpa-attr-value: "4"
              operator: "="
              unit: "GB"
          - hpa-feature: memoryPageSize
            hpa-version: v1
            hpa-hw-arch: generic
            hpa-feature-attributes:
            - hpa-attr-key: memoryPageSize
              hpa-attr-value: "2"
              operator: "="
              unit: "GB"

# min guarantee constraints
- cloud_min_guarantee:
    type: attribute
    demands: [vG]
    properties:
      evaluate:
        cpu_min_guarantee: true
        mem_min_guarantee: true

# check capacity
- check_cloud_capacity:
  type: vim_fit
  demands: [vG]
  properties:
    vim-controller: multicloud
    request:
      vCPU: 10
      mem:
        quantity: {get_param: REQUIRED_MEM}
        unit: GB
      disk:
        quantity: {get_param: REQUIRED_DISK}
        unit: GB

# objective function
optimization:
  minimize:
    sum:
    - distance_between:
      - customer_loc
      - vGMuxInfra
    - distance_between:
      - customer_loc
      - vG
  • No labels