-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Decouple standard flavors from flavor naming (#319)
* Attempt at decoupling standard flavors from flavor naming Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * made ssd flavors recommended (maybe even remove them entirely) Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * First shot at conformance test for the newly split-up standards Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Appease flake8 by removing unused imports Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Fix scs-0100-v4-flavors.yaml (empty lists) as well as mode for flavors-openstack.py (executable) Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Appeased markdown-lint; harmonized extra-spec key with script: scs:cpu-type instead of scs:vCPU-type Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Adjusted/amended Conformance Tests sections according to scs-0001-v1. Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Make properties a first-class subject of this standard Any flavor that carries any of these must also have the corresponding semantics, otherwise no discoverability Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * SSD flavors are mandatory (revert b7d655a) Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Rename scs:name-v4 to v2 because the naming scheme has not changed since v2 Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Make requirements more precise, enhance discoverability Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Change scs-0100-v3 in place because the change doesn't render any implementation unconformant Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Tool to generate input for osism's flavor manager from this standard's yaml file Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Include v1 names, make name handling more explicit Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Include v1 names Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Appease flake8: remove unused variable Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> * Added improvements to standard flavors. Define cpu-type and diskN-types and cross-reference flavor-naming. Mention live-migration consequence. Signed-off-by: Kurt Garloff <kurt@garloff.de> --------- Signed-off-by: Matthias Büchse <matthias.buechse@cloudandheat.com> Signed-off-by: Kurt Garloff <kurt@garloff.de> Co-authored-by: Kurt Garloff <kurt@garloff.de>
- Loading branch information
Showing
7 changed files
with
637 additions
and
68 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,150 @@ | ||
--- | ||
title: SCS Standard Flavors and Properties | ||
type: Standard | ||
status: Draft | ||
track: IaaS | ||
--- | ||
|
||
## Introduction | ||
|
||
## Motivation | ||
|
||
In OpenStack environments there is a need to define different flavors for instances. | ||
The flavors are pre-defined by the operator, the customer can not change these. | ||
OpenStack providers thus typically offer a large selection of flavors. | ||
|
||
While flavors can be discovered (`openstack flavor list`), it is helpful for users (DevOps teams), | ||
to have a guaranteed set of flavors available on all SCS clouds, so these need not be discovered. | ||
|
||
## Properties (extra specs) | ||
|
||
The following extra specs are recognized, together with the respective semantics: | ||
|
||
- `scs:name-vN=NAME` (where `N` is `1` or `2`, and `NAME` is some string) means that the | ||
flavor is one of the | ||
standard SCS flavors, and the requirements of Section "Standard SCS flavors" below apply. | ||
- `scs:cpu-type=shared-core` means that _at least 20% of a core in >99% of the time_, | ||
measured over the course of one month (1% is 7,2 h/month). The `cpu-type=shared-core` | ||
corresponds to the `V` cpu modifier in the [flavor-naming spec](./scs-0100-v3-flavor-naming.md), | ||
other options are `crowded-core` (`L`), `dedicated-thread` (`T`) and `dedicated-core` (`C`). | ||
- `scs:diskN-type=ssd` (where `N` is a nonnegative integer, usually `0`) means that the | ||
root disk `N` must support 1000 _sequential_ IOPS per VM and it must be equipped with | ||
power-loss protection; see [scs-0110-v1-ssd-flavors](./scs-0110-v1-ssd-flavors.md). | ||
The `disk`N`-type=ssd` setting corresponds to the `s` disk modifier, other options | ||
are `nvme` (`p`), `hdd` (`h`) and `network` (`n`). Only flavors without disk and | ||
those with `diskN-type=network` can be expected to support live-migration. | ||
|
||
Whenever ANY of these are present on ANY flavor, the corresponding semantics must be satisfied. | ||
|
||
## Standard SCS flavors | ||
|
||
These are flavors that must exist on standard SCS clouds (x86-64). | ||
|
||
### Mandatory | ||
|
||
| Recommended name | vCPUs | vCPU type | RAM [GiB] | Root disk [GB] | Disk type | | ||
| ---------------- | ------ | ------------- | ---------- | --------------- | ---------- | | ||
| SCS-1V-4 | 1 | shared-core | 4 | | | | ||
| SCS-2V-8 | 2 | shared-core | 8 | | | | ||
| SCS-4V-16 | 4 | shared-core | 16 | | | | ||
| SCS-4V-16-100s | 4 | shared-core | 16 | 100 | ssd | | ||
| SCS-8V-32 | 8 | shared-core | 32 | | | | ||
| SCS-1V-2 | 1 | shared-core | 2 | | | | ||
| SCS-2V-4 | 2 | shared-core | 4 | | | | ||
| SCS-2V-4-20s | 2 | shared-core | 4 | 20 | ssd | | ||
| SCS-4V-8 | 4 | shared-core | 8 | | | | ||
| SCS-8V-16 | 8 | shared-core | 16 | | | | ||
| SCS-16V-32 | 16 | shared-core | 32 | | | | ||
| SCS-1V-8 | 1 | shared-core | 8 | | | | ||
| SCS-2V-16 | 2 | shared-core | 16 | | | | ||
| SCS-4V-32 | 4 | shared-core | 32 | | | | ||
| SCS-1L-1 | 1 | crowded-core | 1 | | | | ||
|
||
### Recommended | ||
|
||
| Recommended name | vCPUs | vCPU type | RAM [GiB] | Root disk [GB] | Disk type | | ||
| ---------------- | ------ | ------------- | ---------- | --------------- | ---------- | | ||
| SCS-1V-4-10 | 1 | shared-core | 4 | 10 | (any) | | ||
| SCS-2V-8-20 | 2 | shared-core | 8 | 20 | (any) | | ||
| SCS-4V-16-50 | 4 | shared-core | 16 | 50 | (any) | | ||
| SCS-8V-32-100 | 8 | shared-core | 32 | 100 | (any) | | ||
| SCS-1V-2-5 | 1 | shared-core | 2 | 5 | (any) | | ||
| SCS-2V-4-10 | 2 | shared-core | 4 | 10 | (any) | | ||
| SCS-4V-8-20 | 4 | shared-core | 8 | 20 | (any) | | ||
| SCS-8V-16-50 | 8 | shared-core | 16 | 50 | (any) | | ||
| SCS-16V-32-100 | 16 | shared-core | 32 | 100 | (any) | | ||
| SCS-1V-8-20 | 1 | shared-core | 8 | 20 | (any) | | ||
| SCS-2V-16-50 | 2 | shared-core | 16 | 50 | (any) | | ||
| SCS-4V-32-100 | 4 | shared-core | 32 | 100 | (any) | | ||
| SCS-1L-1-5 | 1 | crowded-core | 1 | 5 | (any) | | ||
|
||
### Guarantees and properties | ||
|
||
The figures given in the table (number of CPUs, amount of RAM, root disk size) must match | ||
precisely the corresponding figures in the flavor. | ||
|
||
In addition, the following properties must be set (in the `extra_specs`): | ||
|
||
- `scs:name-v1` to the recommended name, but with each dash AFTER the first one replaced by a colon, | ||
- `scs:name-v2` to the recommended name, | ||
- `scs:cpu-type` to `shared-core` or `crowded-core`, reflecting the vCPU type, | ||
- `scs:disk0-type` not set if no disk is provided, otherwise set to `ssd` or some other | ||
value, reflecting the disk type. | ||
|
||
### Remarks | ||
|
||
We expect the most used vCPU:RAM[GiB] ratio to be 1:4. | ||
|
||
Note that all vCPUs of SCS standard flavors are oversubscribed — the smallest `1L-1` | ||
flavor allows for heavy oversubscription (note the `L`), and thus can be offered very | ||
cheaply — imagine jump hosts ... | ||
|
||
The design allows for small clouds (with CPUs with 16 Threads, 64GiB RAM | ||
compute hosts) to offer all flavors. | ||
|
||
Except for the two flavors with SSD root volume, disks types are not specified | ||
(and expected to be network disks (Ceph/Cinder) or local SATA/SAS disks typically). | ||
|
||
We only included a limited variation of disk sizes — this reflects that | ||
for the standard networked cinder | ||
disks, you can pass `block_device_mapping_v2` on server (VM) creation to | ||
allocate a boot disk of any size you desire. We have scaled the few | ||
recommended disk sizes with the amount of RAM. For each flavor there is | ||
also one _without_ a pre-attached disk — these are meant to be used | ||
to boot from a volume (either created beforehand or allocated on-the-fly | ||
with `block_device_mapping_v2`, e.g. | ||
`openstack server create --flavor SCS-1V-2 --block-device-mapping sda=IMGUUID:image:12:true` | ||
to create a bootable 12G cinder volume from image `IMGUUID` that gets tied to the VM | ||
instance life cycle.) | ||
|
||
## Conformance Tests | ||
|
||
The script `flavors-openstack.py` will read the lists of mandatory and recommended flavors | ||
from a yaml file provided as command-line argument, connect to an OpenStack installation, | ||
and check whether the flavors are present and their extra specs are correct. Missing | ||
flavors will be reported on various logging channels: error for mandatory, info for | ||
recommended flavors. Incorrect extra specs will be reported as error in any case. | ||
The return code will be non-zero if the test could not be performed or if any error was | ||
reported. | ||
|
||
## Operational tooling | ||
|
||
The [openstack-flavor-manager](https://github.com/osism/openstack-flavor-manager) is able to | ||
create all standard, mandatory SCS flavors for you. It takes input that can be generated by | ||
`flavor-manager-input.py`. | ||
|
||
## Previous standard versions | ||
|
||
The list of standard flavors used to be part of the flavor naming standard up until | ||
[version 3](scs-0100-v3-flavor-naming.md). The following changes have been made to | ||
the list in comparison with said standard: | ||
|
||
- the flavor names have been turned into recommendations, and | ||
- the properties have been introduced in order to help discoverability. | ||
|
||
Note that the flavors with fixed size root disks have all moved to Recommended | ||
with [scs-0100-v3](scs-0100-v3-flavor-naming.md). | ||
This means that they are not a certification requirement any longer, | ||
but we still recommend implementing these for backwards compatibility reasons. | ||
Also in that standard, two flavors with SSD+ root disks have been added, as defined in | ||
[scs-0110-v1-ssd-flavors.md](scs-0110-v1-ssd-flavors.md) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
SCS-Spec: | ||
# Empty lists so flavor-names-openstack.py only checks the names for scs-0100. | ||
# The list of flavors will be checked with flavors-openstack.py for scs-0103. | ||
MandatoryFlavors: [] | ||
RecommendedFlavors: [] |
Oops, something went wrong.