Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

cloud-infrastructure and cloud-regions in A&AI DB is in Amsterdam release.

Introducing following:

...

Sequence Diagrams

Discovery of HPA-flavors when cloud-region is added

https://sequencediagram.org/index.html?initialData=C4S2BsFMAIGFwPYFcAmBaASpA5iBA7aASXzGgBEQBnAYwQDdIAnATwCg2AHAQydBpA98waAFUqzLr36Duw6AFEAyhil8QAoSICC2omplboAWSThQ8ZOgBCTBAGtJPdZrkjT5kJdRoACuCRcfAMNWXksAFsEYEgANSJjaDZxZjQAPmUMAC4xCSZobhQUKjhEHyYcPGDM9N0iHO0i0qs0CtwCaGAEToALGBB8RmEEVjZMgB40NDroHKUkGhpIKioAegAzbhAAiuS8ybRMuYWllY2tncgxlXSPCzKbO0cmHIA5aJB1lgKisCroBDraD4SAAd2gNAerUqBDYdy8UNsDlSaXh3keyJe0CUkCgNGAJWAfWgnACQWgACNuBIUADCAAdfDxYxoYAsTgwQG9bgiSEtNpVOFme4tJHPW7ChEtfyBAY5AAqTBA2GwzGBYIhUIFHUKKD+sLRUJlQXSkWicQSOQA4pAROtwNx6CM1rFjEoQAAvZarEhUYByJaddnLIWedF+MkDA5mmLMnJYKicAgSaCgsA9ArgcBBjklKhIThJviQFChkU+Y0DU2QKKxy3QG0iFC2i4lLmM+2O52rV3ur1rX3+-CneXBkqMqC8eQDEkVeh4JB5mKcMtSiuR-DRmvmuPQBNJ-ApgAUaaJ0Gb-u2VAAlKvw5X8BKw0aN28RhFuOBPTBO06mC63W-AdDyHJZR1zaBGTkWkFF8bRoAGdZ3x5f4Bi6RQ4LQX9nUg-BqWgSAAA8OXxEtKW+AB5V5tF8O8X1lR80jqBomlg7QsIdP8Smg3DqSoBABB5Mi2KwyAeSQCpxzw-BaTAbjgGAJUKSQGISiQGS1UZIkYD5coYWCIA

Periodic Discovery of HPA-flavors

https://sequencediagram.org/index.html?initialData=C4S2BsFMAIAVIE4gPYBMQGNroM4eQG6ICe0yAZtNAKKwCCAtOeAIYHII4BQXADiwlAYQ-AHbBoAWQCu4UAGFwyaagYAhBMgDWiPgKEiW4qbIVKVDWOGkBzEKL2DMh43ToBJRwbESASpABbZGBIADV3SR4uUWCYQkQTORBFZVUNbUQALmgAMQ5oSBYMAAtocMloYGJeSGjYsiIERLNUy2s7UWy8psKSsojoBEg7ZAcZJJSLK1t7BgA+cZap9vts+CQ0TBp6bBA8eIRSGNByTBZQUa5F5PNVaY7oef8gkPLsgHFICWY2DhwAelCFQAyiAAF6QAHuUQ4YBGDAwKo1bjHGBIGzFCQUZo3Vr3VbQADyNRhcIwWn6khw0GkOBgP3YTRCCACABpoAAdUR0MHSIY0unUgDkQOgoIhOCFlUQAU53IA6sCBZDoEL7LD4YjqpApczZVzgMhBpBeEM6cYCAIULToPgArxpCFoDZNNJeDgAHRXUy45YzUQAHgYDGesTe0H8OF4ozp0AA7mBSgy-tAcG7o4JIKh2Vy48UvvmmvljpVCzABDBIDFbKUuWblAgEdS2CwQKwAEZQaD2Uto4YoUTQcj5YDFPZD1iM70TW5tf1PQJhiIfL7YL6t8DU0YFIpJyccQEg8GQf7QjWiBGVbXTpZ3FaB4Oh14DbKR6MwmAJ0druFtlH1dFMTIShrkmO9-WyAARdc-27C9rFQGACHkWAAFUcHZAJAlTY8c1EXAKRwY9oCMVAClEYpNTIrleFYYBhxZIdCmAPkVTTXgMxCMj21IUdzgnX4EBvX1wI6eZQNnfFOmgAA5DgAhYcBj3+YAECMHA6JgLlkwQQ8xWUs84QvLUajlewGIUi5B0NIkZLoWA11OUQszlWhGB06kLPOYSwLnMS5jcdwVwkSAAA89lAUQbG2dz904MhrPzY0RjGH1fKkoMGEC19IXfWMv1KRTwBipg4ubfDexAJpEN-TcfMk+9xLShr-WgYK1zkFhoHbL440gKs5TCiL7GitzSsE8rqNEZy43AUhcHwRoXLtB0QgYF1lHdL0JLxRqAo8TI6A4uaOrhAURugQLLtgdw5VIkjNyNFhjtIDBnqKMBSA1Fit0HXpa1EMadO6lg6TI7dvptcz5POAdoCgARxC9LggA

VNFC Instantiation 

https://sequencediagram.org/index.html?initialData=C4S2BsFMAIDUDkBiBhaBJAdgZ2AQw6LqAPYbSLjEDu0AIiLgOYBOuAtgFAcAOuzoAYxC8C0AMoB5Hn0HD8waAFkAruFDJKygCbT+IISIUTEu2YegAFYuH0BPU-rmiAgs7RcOkgLQA+YwC5oACVIAEdlSBxoYGJoRkgFAB0MAU0tL2ZIRhBSABpoACNIhQBRC2cvADNwXAA3YmZofC04NEUvYFtuGGSACixIDBatSGYQWsgWkAxKhrYiHLJK5mI2OCRUYEg2bhqt6C9oZLLnaGnZ5nmSDHyBhWJK6FTibQysxaxc5NxKyumwWxNIZA0BeH5-DAAs4zOYLUgASmgHFwanQj0gAA9do4FNU6g1oJlKqNBgJItALoT3qRodDuMpcSs1pIOMZfK40NBAgBxBJPNJvbI086w64UglYbpCP4CKlC7CsxAAHi8Xg5XOCCWUzDIz1emXlWGO5SqNXqzCwHAwxH2xAmjWM+SsNgEtkCAFUsNNGNBuNY7E9SDhWNNgEaMPEFMAABYwIpRA2LZICWMCADWZ0e+EBJ1N+MayWjuCwFLNDTexMyKUg+RAj2tuJeQ1yoxWzGSkHAA2gAyGJcykqDcdw6eisRZkhVXmMGpCg+wMCoYGjRxSAsTeVL+apldJNdXsDaHS6MAe0Vj-Je6Q3GA4ne7deg1ugmOxQlxZcaRJJ1ZLBMfrb-ks0xaN654wDeAD0eLmoq7JuDyfIaFegofNCFxXEmkKPJKkDSvocpoXwMDZBMZAFICkjJASkboaKixNAULwKCi4CXvq1LYKu0C9LmMENJ80AnBSkBENq5LNOBICNEQwBjAUDKRPCipThygRzn6C5Wjap72tAjqWP6roel6Ea+kZgICEGcm4KGf6PDasYWqukknPkLCQJMgIziijANMuazJH8jDiX+DLgYUxSEZu8alCa-HMNp+xjIw0b3I8AToAoIAlq+eFbC0yQxkQTTgGxwl+i6gLJtZIYECWxHQKQXhMXwIwtLUDDiLQmyxJVdhJRBICpel+mIIEfGfj2nb5QxOWFMWkxNWQMYwFgVmZJ4EhTjO6mRJp3ZLjG0DIRx8q3DNAgFUJ8VTS5wKHu0nTdE1jyrex16cXeQxbb4KhqCAp1aIEyCZEQkBeGIox6VZbDzMCyStE9J75Hqn3ykCLSTduIqXHCt4cEAA

A&AI Schema Changes

Image RemovedRequirements that are kept in mind are :

  • Expose HW capability of various CPU architecture (Intel x86,  ARM etc...) in generic fashion.
  • Provide flexibility to expose CPU architecture and vendor specific features.
  • Support for multiple Clouds such as Openstack clouds, AWS Cloud,  Azure Cloud etc...
  • No hardcoding of HPA feature names OR attribute names in ONAP (other than Multi-Cloud plugin)
  • HPA Impact on the AAI Project
  • Please refer to HPA Requirement & Capability Specification

Following format is used to represent the HPACapability:

  • Data centers typically have flavors (openstack calls them flavors,  Azure calls them VM sizes and AWS calls them as Instance types). Each flavor is represented by hardware features.   When these are discovered by ONAP,  there are few ways to represent them in A&AI DB. 
    • Approach 1:
      • flavors as children to the cloud-region (Already existing)
      • Represent HPA capabilities under each flavor (HPA capabilities as children of each flavor)
    • Approach 2:
      • flavors as children to the cloud-region (Already existing). Also, represent HPA capabilities also children to the cloud-regions.
      • Then provide relationship between flavors and capabilities.
    • Approach 3:
      • Approach 1 +
      • Create another tree with capability to region+flavor list.
    • Which approach to follow?  Some guidance from A&AI team.  Requirement is this:
      • During VNF instantiation, OOF gets hold of hardware requirements and based on that requirements, it needs to find out the best cloud-region and flavor.
      • Would Approach 3 seem possible?
  • Each HPACapability is defined as 
    {HPACapability-id,HPAFeature, Schema Version, hardware-architecture, [List of HPAAttributes] - names and values}
  • HPAFeatureAttribute is <hpaAttributeKey, hpaAttributeValue>
  • Refer Supported HPA Capability Requirements(DRAFT) for more specific Capability names and values.

A&AI Schema Changes

Image Added



Example: Run time view of A&AI graph instance

Image RemovedImage Added

Code Block
languagexml
themeEmacs
titleCurrent AAI Schema
collapsetrue
<java-type name="CloudRegion">
    <xml-root-element name="cloud-region" />
    <java-attributes>
        <xml-element java-attribute="cloudOwner" name="cloud-owner" required="true" type="java.lang.String" xml-key="true">
            <xml-properties>
                <xml-property name="description" value="Identifies the vendor and cloud name. First part of composite key should be formatted as vendor-cloudname" />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudRegionId" name="cloud-region-id" required="true" type="java.lang.String" xml-key="true">
            <xml-properties>
                <xml-property name="description" value="Identifier used by the vendor for the region. Second part of composite key" />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudType" name="cloud-type" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="Type of the cloud (e.g., openstack)" />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="ownerDefinedType" name="owner-defined-type" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="Cloud-owner defined type indicator (e.g., dcp, lcp)" />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudRegionVersion" name="cloud-region-version" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="Software version employed at the site.  NOTE - THIS FIELD IS NOT KEPT UP TO DATE." />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="identityUrl" name="identity-url" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="URL of the keystone identity service" />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudZone" name="cloud-zone" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="Zone where the cloud is homed.  NOTE - THIS FIELD IS NOT CORRECTLY POPULATED." />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="complexName" name="complex-name" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="complex name for cloud-region instance.  NOTE - THIS FIELD IS NOT CORRECTLY POPULATED." />
            </xml-properties>
        </xml-element>
        <xml-element default-value="false" required="true" java-attribute="sriovAutomation" name="sriov-automation" type="java.lang.Boolean">
            <xml-properties>
                <xml-property name="defaultValue" value="false"/>
                <xml-property name="description" value="Whether the cloud region supports (true) or does not support (false) SR-IOV automation." />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudExtraInfo" name="cloud-extra-info" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="ESR inputs extra information about the VIM or Cloud which will be decoded by MultiVIM." />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudEpaCaps" name="cloud-epa-caps" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="MultiVIM will discover and expose EPA capabilities." />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="resourceVersion" name="resource-version" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="Used for optimistic concurrency.  Must be empty on create, valid on update and delete." />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="volumeGroups" name="volume-groups" type="inventory.aai.onap.org.v11.VolumeGroups" />
        <xml-element java-attribute="tenants" name="tenants" type="inventory.aai.onap.org.v11.Tenants" />
        <xml-element java-attribute="flavors" name="flavors" type="inventory.aai.onap.org.v11.Flavors" />
        <xml-element java-attribute="groupAssignments" name="group-assignments" type="inventory.aai.onap.org.v11.GroupAssignments" />
        <xml-element java-attribute="snapshots" name="snapshots" type="inventory.aai.onap.org.v11.Snapshots" />
        <xml-element java-attribute="images" name="images" type="inventory.aai.onap.org.v11.Images" />
        <xml-element java-attribute="dvsSwitches" name="dvs-switches" type="inventory.aai.onap.org.v11.DvsSwitches" />
        <xml-element java-attribute="oamNetworks" name="oam-networks" type="inventory.aai.onap.org.v11.OamNetworks" />
        <xml-element java-attribute="availabilityZones" name="availability-zones" type="inventory.aai.onap.org.v11.AvailabilityZones" />
        <xml-element java-attribute="relationshipList" name="relationship-list" type="inventory.aai.onap.org.v11.RelationshipList" />
        <xml-element java-attribute="esrSystemInfoList" name="esr-system-info-list" type="inventory.aai.onap.org.v11.EsrSystemInfoList" />
        <xml-element container-type="java.util.ArrayList" java-attribute="vipIpv4AddressList" name="vip-ipv4-address-list" type="inventory.aai.onap.org.v11.VipIpv4AddressList" />
        <xml-element container-type="java.util.ArrayList" java-attribute="vipIpv6AddressList" name="vip-ipv6-address-list" type="inventory.aai.onap.org.v11.VipIpv6AddressList" />
    </java-attributes>
    <xml-properties>
        <xml-property name="description" value="cloud-region designates an installation of a cloud cluster or region or instantiation." />
        <xml-property name="indexedProps" value="cloud-owner,cloud-region-id,cloud-type,owner-defined-type" />
        <xml-property name="nameProps" value="owner-defined-type" />
        <xml-property name="container" value="cloud-regions" />
        <xml-property name="namespace" value="cloud-infrastructure" />
    </xml-properties>
</java-type>
Code Block
languagexml
themeEmacs
titleModified AAI Schema
collapsetrue
<java-type name="CloudRegionFlavor">
    <xml-root-element name="cloud-regionflavor" />
    <java-attributes>
        <xml-element java-attribute="cloudOwnerflavorId" name="cloudflavor-ownerid" required="true" type="java.lang.String" xml-key="true">
            <xml-properties>
                <xml-property name="description" value="IdentifiesFlavor theid, vendorexpected andto cloudbe name.unique First part of composite key should be formatted as vendor-cloudname" across cloud-region."/>
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudRegionIdflavorName" name="cloudflavor-region-idname" required="true" type="java.lang.String" xml-key="true">
            <xml-properties>
                <xml-property name="description" value="Identifier used by the vendor for the region. Second part of composite key" Flavor name"/>
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudTypeflavorVcpus" name="cloudflavor-typevcpus" type="java.lang.StringInteger">
            <xml-properties>
                <xml-property name="description" value="TypeNumber of the cloud (e.g., openstack)" />CPUs"/>
             </xml-properties>
        </xml-element>
        <xml-element java-attribute="ownerDefinedTypeflavorRam" name="ownerflavor-defined-typeram" type="java.lang.StringInteger">
            <xml-properties>
                <xml-property name="description" value="Cloud-ownerAmount defined type indicator (e.g., dcp, lcp)" of memory"/>
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudRegionVersionflavorDisk" name="cloudflavor-region-versiondisk" type="java.lang.StringInteger">
            <xml-properties>
                <xml-property name="description" value="Software version employed at the site.  NOTE - THIS FIELD IS NOT KEPT UP TO DATE." />
     Disk space"/>
            </xml-properties>
        </xml-properties>
        </xml-element>
        <xml-element java-attribute="identityUrlflavorEphemeral" name="identityflavor-urlephemeral" type="java.lang.StringInteger">
            <xml-properties>
                <xml-property name="description" value="URLAmount of theephemeral keystonedisk identity servicespace" />
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="cloudZoneflavorSwap" name="cloudflavor-zoneswap" type="java.lang.String">
            <xml-properties>
                <xml-property name="description" value="Zoneamount whereof theswap cloud is homed.  NOTE - THIS FIELD IS NOT CORRECTLY POPULATED." space allocation"/>
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="complexNameflavorIsPublic" name="complexflavor-is-namepublic" type="java.lang.StringBoolean">
            <xml-properties>
                <xml-property name="description"
                              value="complex name for cloud-region instance.  NOTE - THIS FIELD IS NOT CORRECTLY POPULATED." whether flavor is available to all users or private to the tenant it was created in."/>
            </xml-properties>
        </xml-element>
        <xml-element default-value="falsejava-attribute="flavorSelflink" name="flavor-selflink" required="true" java-attribute="sriovAutomation" name="sriov-automation" type="java.lang.BooleanString">
            <xml-properties>
                <xml-property name="defaultValue"
value="false"/>                 <xml-property name="description" value="WhetherURL theto cloudendpoint regionwhere supportsAAI (true)can orget does not support (false) SR-IOV automation." more details"/>
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="resourceVersionflavorDisabled" name="resourceflavor-versiondisabled" type="java.lang.StringBoolean">
            <xml-properties>
                <xml-property name="description" value="UsedBoolean foras optimisticto concurrency.whether this Mustflavor beis emptyno on create, valid on update and delete." longer enabled"/>
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="volumeGroupshpaCapabilities" name="volumehpa-groups" capabilities"
                     type="inventory.aai.onap.org.v12v13.VolumeGroupsHpaCapabilities">
/>            <xml-element java-attribute="tenants" name="tenants" type="inventory.aai.onap.org.v12.Tenants" />properties>
                <xml-elementproperty java-attributename="flavorsdescription" namevalue="flavors" type="inventory.aai.onap.org.v12.Flavors" />List of HPA Capabilities associated with this flavor"/>
         <xml-element java-attribute="groupAssignments" name="group-assignments" type="inventory.aai.onap.org.v12.GroupAssignments" />   </xml-properties>
        </xml-element>
        <xml-element java-attribute="snapshotsresourceVersion" name="snapshotsresource-version" type="inventoryjava.aai.onap.org.v12.Snapshots" />lang.String">
            <xml-element java-attribute="images" name="images" type="inventory.aai.onap.org.v12.Images" />properties>
                <xml-elementproperty java-attributename="dvsSwitchesdescription" name="dvs-switches" type="inventory.aai.onap.org.v12.DvsSwitches" />
                <xml-element java-attribute="oamNetworks" name="oam-networks" type="inventory.aai.onap.org.v12.OamNetworks" />         <xml-element java-attribute value="availabilityZones" name="availability-zones" type="inventory.aai.onap.org.v12.AvailabilityZones" />Used for optimistic concurrency.  Must be empty on create, valid on update and delete."/>
            </xml-properties>
        </xml-element>
        <xml-element java-attribute="relationshipList" name="relationship-list" type="inventory
                     type="inventory.aai.onap.org.v12v13.RelationshipList" />
    </java-attributes>
    <xml-element container-type="java.util.ArrayList" java-attribute="vipIpv4AddressList"properties>
        <xml-property name="vip-ipv4-address-listdescription" typevalue="inventory.aai.onap.org.v12.VipIpv4AddressList" Openstack flavor."/>
        <xml-element container-type="java.util.ArrayList" java-attribute="vipIpv6AddressList" name="vip-ipv6-address-list" type="inventory.aai.onap.org.v12.VipIpv6AddressList" property name="nameProps" value="flavor-name"/>
        <xml-elementproperty java-attributename="hpaCapabilitiesindexedProps" namevalue="hpa-capabilities" type="inventory.aai.onap.org.v12.HPACapabilities" flavor-name,flavor-id"/>
    </java-attributes>     <xml-properties>property name="dependentOn" value="cloud-region"/>
        <xml-property name="descriptioncontainer" value="cloud-region designates an installation of a cloud cluster or region or instantiation. In cloud, this could be an LCP or DCP. Cloud regions are uniquely identified by a composite key, cloud-owner + cloud-region-id. The format of the cloud-owner is vendor-cloudname" />flavors"/>
    </xml-properties>
</java-type>

<java-type name="HpaCapabilities">
    <xml-properties>
        <xml-property name="description" value="Collection of HPA Capabilities"/>
    </xml-properties>
    <xml-root-element name="hpa-capabilities"/>
    <java-attributes>
        <xml-property name="indexedProps" value="cloud-owner,cloud-region-id,cloud-type,owner-defined-type" />-element container-type="java.util.ArrayList" java-attribute="hpaCapability" name="hpa-capability"
                   <xml-property name="nameProps" value="owner-defined-type" type="inventory.aai.onap.org.v13.HpaCapability"/>
    </java-attributes>
</java-type>

 <xml<java-propertytype name="containerHpaCapability" value>
<xml-root-element name="cloudhpa-regionscapability" />
<java-attributes>
    <xml-element   <xml-property name="namespace" value="cloud-infrastructure" />java-attribute="hpaCapabilityId" name="hpa-capability-id" required="true" type="java.lang.String"
      </xml-properties> </java-type>   <!-- NEW NODES for HPA Capabilities --> <javaxml-type namekey="HPACapabilitiestrue">
        <xml-properties>
            <xml-property name="description" value="CollectionUUID ofto HPAuniquely Capabilities" identify a HPA capability"/>
        </xml-properties>
    <xml-root-element name="hpa-capability-list" />
    <java-attributes>
  </xml-element>
     <xml-element container-type="java.util.ArrayList" java-attribute="hpaCapabilityhpaFeature" name="hpa-capabilityfeature" required="true" type="inventoryjava.aai.onap.org.v12.HPACapability" /lang.String">
    </java-attributes> </java-type>  <java-type name="HPACapability">
<xml-properties>
            <xml-property name="description" value="RepresentsName aof HPAthe capabilityHPACapability" />
        </xml-properties>
<xml-root-element name="hpa-capability" />
<java-attributes>    </xml-element>
    <xml-element java-attribute="hpaCapabilityNameversion" name="hpa-capability-nameversion" type="java.lang.String">
/>        <xml-element java-attribute="version" name="hpa-version" type="java.lang.String" />
    properties>
            <xml-property name="description" value="HPA schema version"/>
        </xml-properties>
    </xml-element>
    <xml-element java-attribute="hardware-architecturehardwareArchitecture" name="hpa-hw-arch" type="java.lang.String">
/>        <xml-element container-type="java.util.ArrayList" java-attribute="hpaFeatureAtrribute" name="hpa-attribute" type="inventory.aai.onap.org.v12.HPAFeatureAtrribute" />properties>
            <xml-property name="description" value="Hardware architecture"/>
        </xml-properties>
    </xml-element>
    <xml-element container-type="java.util.ArrayList" java-attribute="hpaFeatureAtrributeresourceVersion" name="hparesource-attributeversion" type="inventoryjava.aai.onap.org.v12.HPAComplexAtrribute" />
</java-attributes>
</java-type>

<java-type name="HPAFeatureAttribute">lang.String">
        <xml-properties>
            <xml-property name="description" value="HPA Capability simple attributes" />
</xml-properties>
<xml-root-element name="hpa-attribute" />
<java-attributes>
                         <xml-element java-attribute value="hpaAttributeKey" name="hpa-attr-key" type="java.lang.String" />Used for optimistic concurrency.  Must be empty on create, valid on update and delete."/>
       <xml-element java-attribute="hpaAttributeValue" name="hpa-attr-value" type="java.lang.String" /> </xml-properties>
    </xml-element>
    <xml-element java-attribute="hpaAttributeValueTyperelationshipList" name="hpa-attr-value-type" type="java.lang.String" />
</java-attributes>
</java-type>

<java-type name="HPAComplexAttribute">
<xml-properties>relationship-list"
                 type="inventory.aai.onap.org.v13.RelationshipList"/>
    <xml-element container-type="java.util.ArrayList" java-attribute="hpaFeatureAttribute" name="hpa-feature-attribute"
    <xml-property name="description" value="HPA Capabilities with a set of FeatureAttributeList"             type="inventory.aai.onap.org.v13.HpaFeatureAttribute"/>
</xmljava-attributes>
<xml-properties>
    <xml-root-elementproperty name="hpa-complex-attribute" "description" value="Represents a HPA capability"/>
<java-attributes>     <xml-elementproperty container-typename="java.util.ArrayListnameProps" java-attributevalue="hpaFeatureAtrribute" name="hpa-attribute" type="inventory.aai.onap.org.v12.HPAFeatureAtrribute" hpa-feature"/>
    <xml-property name="indexedProps" value="hpa-feature,hpa-hw-arch,hpa-capability-id"/>
    <xml-property name="dependentOn" value="flavor"/>
    <xml-property name="container" value="hpa-capabilities"/>
</javaxml-attributes>properties>
</java-type>

HPA Feature Definition

Requirements that are kept in mind are :

  • Expose HW capability of various CPU architecture (Intel x86,  ARM etc...) in generic fashion.
  • Provide flexibility to expose CPU architecture and vendor specific features.
  • Support for multiple Clouds such as Openstack clouds, AWS Cloud,  Azure Cloud etc...
  • No hardcoding of HPA feature names OR attribute names in ONAP (other than Multi-Cloud plugin)

Following table provides HPA features and attributes.  Also, it describes matching constraints for each HPA feature. These constrains are applied while finding the best compute-group for placing VNFC.

Following format is used to represent the HPA feature name:

<Hardware or Software feature>-<Generic feature or CPU architecture/vendor specific featuers>-<feature name>

Attributes are represented as:

TBD...

...

AAI Database examples :

Azure

AWS

Openstack VIM

...



<java-type name="HpaFeatureAttribute">
<xml-root-element name="hpa-feature-attribute"/>
<java-attributes>
    <xml-element java-attribute="hpaAttributeKey" name="hpa-attr-key" type="java.lang.String">
        <xml-properties>
            <xml-property name="description" value="name of the specific HPA attribute"/>
        </xml-properties>
    </xml-element>
    <xml-element java-attribute="hpaAttributeValue" name="hpa-attr-value" type="java.lang.String">
        <xml-properties>
            <xml-property name="description"
                          value="JSON string specifying the value, unit and type of the specific HPA attribute"/>
        </xml-properties>
    </xml-element>
    <xml-element java-attribute="resourceVersion" name="resource-version" type="java.lang.String">
        <xml-properties>
            <xml-property name="description"
                          value="Used for optimistic concurrency.  Must be empty on create, valid on update and delete."/>
        </xml-properties>
    </xml-element>
    <xml-element java-attribute="relationshipList" name="relationship-list"
                 type="inventory.aai.onap.org.v13.RelationshipList"/>
</java-attributes>
<xml-properties>
    <xml-property name="description" value="HPA Capability Feature attributes"/>
    <xml-property name="container" value="hpa-capability"/>
</xml-properties>
</java-type>
Code Block
languagejs
themeEmacs
titleEdge Relations
collapsetrue
{
	"from": "flavor",
	"to": "cloud-region",
	"label": "org.onap.relationships.inventory.BelongsTo",
	"direction": "OUT",
	"multiplicity": "MANY2ONE",
	"contains-other-v": "!${direction}",
	"delete-other-v": "NONE",
	"SVC-INFRA": "NONE",
	"prevent-delete": "!${direction}",
	"default": "true",
	"description":""
},
{
	"from": "hpa-capability",
	"to": "flavor",
	"label": "org.onap.relationships.inventory.BelongsTo",
	"direction": "OUT",
	"multiplicity": "MANY2ONE",
	"contains-other-v": "!${direction}",
	"delete-other-v": "NONE",
	"SVC-INFRA": "NONE",
	"prevent-delete": "!${direction}",
	"default": "true",
	"description":""
},
{
	"from": "hpa-capability",
	"to": "cloud-region",
	"label": "org.onap.relationships.inventory.AssociatedWith",
	"direction": "OUT",
	"multiplicity": "MANY2ONE",
	"contains-other-v": "NONE",
	"delete-other-v": "NONE",
	"SVC-INFRA": "NONE",
	"prevent-delete": "!${direction}",
	"default": "true",
	"description":""
},

Sequence Diagrams

Discovery of HPA-flavors when cloud-region is added

Gliffy
nameCloud-Region Init Discovery

Periodic Discovery of HPACapabilities

Gliffy
namePeriodic Discover HPA


VNFC Instantiation 

Gliffy
nameVNFC instantiation

TBD

Following table provides HPA features and attributes.  Also, it describes matching constraints for each HPA feature. These constraints are applied while finding the best cloud-region for placing VNFC.

Attributes are represented as:

TBD...

<HPA feature name



AAI APIs for HPA :

TBD