Configuration for RefStack

Cross Project Spec - None

User Story Tracker - None

Problem description

Problem Definition

Customer decision maker for a choice of OpenStack solution to acquire often need configuration information that was used for certification to decide which solution to choose that ensures interoperability with other openstack environments, and/or portability of applications across OpenStack solutions.

OpenStack operators would like to setup a configuration for an OpenStack deployment that provides interoperability support for their users. Thus, they need information from RefStack about the configuration used for DefCore certification of vendor solution.

Opportunity/Justification

The goal of Openstack interoperability branding is to ensure interoperability between OpenStack clouds to support portability of applications between them. Unfortunately, this portability is heavily dependent on full openstack solution configuration that consists of openstack configuration as well as underlying HW environment configuration.

The proposal is to provide information necessary for operators and decision makers to decide which configuration(s) and which vendor solution will satisfy their interoperability requirements. Configuration information requested is similar to the one that many benchmarking groups, like TPC and SPEC, provide with their results.

Use Cases

User Stories

  • Private Cloud
    • As a Cloud solution decision maker I want to choose private OpenStack solution that meet my application interoperability requirements. Thus, I need to ensure that my openstack solution configuration ensures interoperability.
    • As a Cloud solution decision maker I want to choose private OpenStack solution that meet my application interoperability requirements on hardware vendor of my choice. Thus, I need to ensure that solution interoperability results are applicable on my hardware choice.
    • As a Cloud solution decision maker I want to choose private OpenStack solution for PoC that meet my applications interoperability requirements on hardware that is available in my lab now. Thus, I need to ensure that solution interoperability results are applicable on my hardware choice.
    • As a Cloud solution decision maker I want to choose OpenStack solution that supports multiple hypervisors for my applications and meet interoperability requirements for all of them.
    • As a Cloud operator I want to choose hypervisor for my OpenStack solution configuration that provides application interoperability. Thus, as cloud operator I want to see which hypervisor was used by vendor for refstack result submissions.
    • As a Cloud operator I want to choose container management for my OpenStack solution configuration that provides application interoperability. Thus, as Cloud operator I want to see which container management was used by vendor for refstack result submissions.
    • As a Cloud solution decision maker I want to choose OpenStack solution that supports interoperability for bare metal applications.
    • As a Cloud operator I want to configure my OpenStack solution configuration that ensures bare metal application interoperability. Thus, as Cloud operator I want to see what configuration for OpenStack and what hardware and its configuration used by vendor for refstack result submissions.
    • As a Cloud operator I would like to replicate vendor interoperability results. This requiers exact configuration of complete OpenStack solution, including hardware choices, its configuration, mapping of OpenStack component to hardware and OpenStack configuraion for each OpenStack projects.
  • Public Cloud
    • As a Cloud solution decision maker I want to choose public OpenStack solution that meet my applications interoperability requirements. Thus, I need to ensure that public OpenStack solution provider deploys my applications on the same OpenStack configuration that was used for DevCore Logo certification.
    • As a Cloud solution decision maker I want to choose OpenStack solution that supports containers for my applications and meet interoperability requirements for them.
    • As a Cloud operator I want to choose hypervisor for my OpenStack solution configuration that provides application interoperability. Thus, as Cloud operator I want to see which hypervisor was used by vendor for refstack result submissions.
    • As a Cloud operator I want to choose container management for my OpenStack solution configuration that provides application interoperability. Thus, as Cloud operator I want to see which container management was used by vendor for refstack result submissions.
    • As a Cloud solution decision maker I want to choose OpenStack solution that supports interoperability for bare metal applications.
    • As a Cloud operator I would like to replicate vendor interoperability results. This requiers exact configuration of complete OpenStack solution, including hardware choices, its configuration, mapping of openstack component to hardware and OpenStack configuraion for each OpenStack projects as chosen by vendor. While these choices are not visible to a user in public cloud, an identifier for an exact environment that was used for RefStack results by the vendor that can be used by the user can be used. That covers, hardware choices, openstack projects configuration, environment in which it is running, Availability Zone, Host Aggregate, High Availability.

Usage Scenarios Examples

  • I want to choose an OpenStack solution
    • I have a list of VM applications that are required to be portable
    • I have a list of docker container based applications that are required to be portable
    • I need to provide environment for my dev/QA team to develop portable applications
    • I have a short list of preferred hardware partners
    • I review openstack vendors that have foundation logo for interoprability to see which ones passed certification on KVM.
    • I review openstack vendors that have foundation logo for interoprability to see which ones passed certficiation on docker containers.
    • I review hardware partners logo at OpenStack interoperability list and choose ones that meet my container and hypervisor requirements
  • I install a chosen vendor OpenStack product as admin in my organization.
    • I review vendor interoperability submission results to configure my deployment so it will pass interoperability testing
    • I run refstack interoperability on it as base validation.
    • I run refstack interoperability on OpenStack public cloud that has logo interoperability certification, say Rackspace.
    • I compare results between themselves and between refstack results on record.
    • If results do not match expectations I send email to interop@openstack.org, a ticket get generated and the issue is escalated to proper level for resolution.
    • If results are successful, I deploy and run an application on my private cloud.
    • I deploy the same application at OpenStack public cloud that has logo interoperability certification, say Rackspace.
    • I compare results of two runs to ensure that they are the same.

Requirements

  • Identification of configuration items and values that are important in parametarizing the interoperability of each specific implementation of OpenStack cloud.
  • Tool to extract openstack configuration files, anonymize them for sensative information, like passwords, and combined them into reporting entity.
  • Enhance RefStack client to use above tool to collect and report pertinent configuration information as defined by DevCore submission guidelines.
  • Definition for unique OpenStack public cloud product+configuration that is submitted to RefStack with the configuration information that is queryable and discoverble by users.

External References

None.

Rejected User Stories / Usage Scenarios

None.