Versions Compared

Key

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

Table of Contents

Introduction

Assumptions

Table of Contents

Introduction


Assumptions

  1. All the hardware are Uniform
    1. Same number of NICs with same PCI ids
    2. Same number of disks with same addresses.
  2. Everything is named and their names are used for reference - In Airship, the name if the filename is not important, but the name in the 'schema' (found in schema/metadata/name) is important.

Deployment Configuration and Strategy

  1. found in schema/metadata/name) is important.

Deployment Configuration and Strategy

This section is added mainly for the completeness purposes. User may chose to configure these values  - only if it is required. For example, with  slow-internet access site, some timeouts may be modified. Or, If user wants to perform some check in-between two actions. 

ParameterSub-Category-1Sub-Category-2DescriptionExample Value
physical_provisioner




deployment_strategy

Name of the strategy to use. User can use the one that is defined in airshipit/treasuremap/global/deployment

See below.

deployment-strategydeploy_intervaldeploy_timeoutdestroy_intervaldestroy_timeout

deploy_interval
The seconds delayed between checks for progress of the step that performs deployment of servers30

deploy_timeout
The maximum seconds allowed for the step that performs deployment of all servers3600

destroy_interval
The seconds delayed between checks for progress of destroying hardware nodes30

destroy_timeout
The maximum seconds allowed for destroying hardware nodes900

join_wait
The number of seconds allowed for a node to join the Kubernetes cluster0

prepare_node_interval
The seconds delayed between checks for progress of preparing nodes30

prepare_node_timeout
The maximum seconds allowed for preparing nodes1800

prepare_site_interval
The seconds delayed between checks for progress of preparing the site10

prepare_site_intervalprepare_site_timeouttimeout
The maximum seconds allowed for preparing the site300

verify_interval
The seconds delayed between checks for progress of verification10

verify_timeout
The maximum seconds allowed for verification60
kubernetes




node_status_interval



node_status_timeout


kubernetes_provisioner




drain_timeout
maximum seconds allowed for draining a node3600

drain_grace_period
seconds provided to Promenade as a grace period for pods to cease1800

clear_labels_timeout_labels_timeout
maximum seconds provided to Promenade to clear labels on a node1800

remove_etcd_timeout
maximum seconds provided to Promenade to allow for removing etcd from a node1800

etcd_ready_timeout
maximum seconds allowed for etcd to reach a healthy state after a node is removed600
armada+




get_releases_timeout
timeout for Retrieving Helm charts releases after deployment300

get_status_timeoutmanifest+timeout
timeout for retrieving status300

manifest+
The name of the manifest document that the workflow will use during site deployment activities'full-site'

post_apply_timeout

7200

validate_design_timeout
Timeout to validate the design.600
Deployment-Strategy
groups

named sets of nodes that will be deployed together.

name
name of the groupmasters

critical
if this group is required to continue to additional phases of deploymenttrue

depends_on
Group names that must be successful before this group can be processed[]

selectors
A list of identifying information to indicate the nodes that are members of this group. Each selector has following 4 filter values


node_namesName of the node
node01


node_labelsLabel of the node
ucp_control_plane: enabled


node_tagsTags in Node
control


rack_namesName of the rack
rack01

success_criteria

A list of identifying information to indicate the nodes that are members of this group.

When no criteria are specified, it means that no checks are done - processing continues as if nothing is wrong




percent_successful_nodesThe calculated success rate of nodes completing the deployment phase.75 would mean that 3 of 4 nodes must complete the phase successfully


minimum_successful_nodesAn integer indicating how many nodes must complete the phase to be considered successful3


maximum_failed_nodesAn integer indicating a number of nodes that are allowed to have failed the deployment phase and still consider that group successful.0


Typical Ordering of groups :is shown below. 


 __________     __________________
|
ntp-node | | monitoring-nodes | ---------- ------------------ | ____V__________ | control-nodes | --------------- |_________________________ | | ______V__________ ______V__________ | compute-nodes-1 | | compute-nodes-2 | ----------------- -----------------

...

ParameterDescriptionExample-Value
vendorVendor of the server chassisIntel
generationGeneration of the chassis model'4'
hw_versionVersion of the chassis model within its generation'3'
bios_versionThe certified version of the chassis BIOS'SE5C ....
boot_modeMode of the default boot of hardware - bios, uefibios
bootstrap_protocolProtocol of boot of the hardware - pxe, usb, hdd'pxe
pxe_interfaceWhich interface to use for network booting within the OOB manager, not OS device0

Device-Aliases:

NICs:

User can categorize the NICs in the hardware as control-plane nics or dataplane nics. In each category he can have one or more NICs.  For example, he can define ctrl_nic1, ctrl_nic2, ctrl_nic3, and data_nic1, data_nic2, data_nic3, etc.  It is better to use names that are self-explanatory - for example, if you have a separate NIC for PXE, name it as pxe_nic. This categorization will be referred in the host-profiles.  For every NIC defined, the below information can be configured. 

...

ParameterDescriptionExample Value
addressThe PCI address of the NIC0000:04:00.0
dev_typeDescription of the NIC'I350 Gigabit Network Connection'
bus_typeThe bus supported'pci'

...

ParameterDescriptionExample Value
addressThe bus address of the Disk0:2.0.0
dev_type

Description of the disk.

'INTEL SSDSC2BB48'
bus_typeThe bus supported'scsi'

...

ParameterSub-category-1Sub-category-2DescriptionExample Value
cpu_set




kvm

'4-43,48-87'
huge_pages




dpdk




size
'1G'


count
32

Host Profiles

The host profiles Following things are covered:

...

For majority of the cases, you only need two host profiles - Dataplane and Control Plane. Of course, the user can create more than 2 and use it accordingly. The below table summarizes the configurable parameters for the host profiles.

Note: One host profile can adopt values from other host profile. It just have to add


Parameter CategorySub Category 1Sub Category 2Sub-Category-
1
2Sub-Category-2DescriptionExample Value 1
Example Value 2
hardware_profileNANA

The hardware profile used by the hostintel_2600.yaml
primary_networkNANA

The main network used for administrationdmz
Interfaces



NANA

Define each and every interfaces of the host in detail.
Name


NA

Name of the Interfacedmz
, data1
device_link

The name of the network
link.dmzdata1slavesNIC Aliases ctrl_nic1data_nic1networksThe networks this interface belongs to.dmz

- private

- management

Nodes

Parameter CategorySub-Category-1Sub-Category-2Sub-Category-3Sub-Category-4DescriptionExample Valueaddressing*
addressnetworkoob
network account credentialstorage
physical_devices
labelsvolume_group partitions*namesizepart_uuid volume_group labels bootablefilesystemmountpointfstypemount_optionsfs_uuidfs_labelvolume_groups
vg_uuidlogical_volumes*namelv_uuidsize filesystemmountpointfstype  mount_options fs_uuidfs_label platform
imagekernelkernel_params    metadata
tags* owner_data rackboot_mac    host_profile    hardware_profile    primary_network    interfaces
          device_link          slaves*          networks*
link.dmz, data1
slaves

NIC Aliases ctrl_nic1, data_nic1
networks

The networks this interface belongs to.dmz,  private, management
storage

































physical_devices



















labels



volume_group



 partitions*




name



size



part_uuid



 volume_group



 labels



 bootable



filesystem




mountpoint



fstype



mount_options



fs_uuid



fs_label

volume_groups















vg_uuid



logical_volumes*




name



lv_uuid



size



 filesystem




mountpoint



fstype



  mount_options



 fs_uuid



fs_label

 platform




















image




kernel




kernel_params




    metadata








tags*



 owner_data



 rack



boot_mac



    host_profile




    hardware_profile




    primary_network




    interfaces







          device_link



          slaves*



          networks*



oob






The ipmi OOB type requires additional configuration to allow OOB management
network


 which node network is used for OOB access.oop
 account


valid account that can access the BMC via IPMI over LANroot
 credential


valid password for the account that can access the BMC via IPMI over LANroot
spechost_profile


Name of the HostProfile that this profile adopts and overrides values from.defaults
metadata






owner_data






<software-component-name> enabled/disabled


openstack-l3-agent: enabled


Nodes

Nodes adopts all values from the profile that it is mapped to and can then again override or append any configuration that is specific to that node. 

Parameter CategorySub-Category-1Sub-Category-2Sub-Category-3Sub-Category-4DescriptionExample Value
addressing*





Contain IP address assignment for all the networks. It is a valid design to omit networks from  this, and in that case the interface attached to the omitted network will be configured as link up with no address
address


It defines a static IP address or dhcp for each network a node should have a configured layer 3 interface on. 10.10.100.12 or dhcp
network


The Network name.oob, private, mgmt, pxe, etc.







*: Array of Values.


Network Definition

...

Source 

(as mentioned in commonaddress.yaml)

Destination
.genesis.hostname.values.nodes[0].name
.masters[0].hostname.values.nodes[1].name
.masters[1].hostname.values.nodes[2].name


Source 

Destination
certificate of calico-etcd-<podname>-node1.values.nodes[0].tls.client.cert
certificate-key calico-etcd-<podname>-node1.values.nodes[0].tls.client.key
certificate of calico-etcd-<podname>-node1-peer.values.nodes[0].tls.peer.cert
certificate-key of calico-etcd-<podname>-node1-peer.values.nodes[0].tls.peer.key
certificate of calico-etcd-<podname>-node2.values.nodes[1].tls.client.cert
certificate-key calico-etcd-<podname>-node2.values.nodes[1].tls.client.key
certificate of calico-etcd-<podname>-node2-peer.values.nodes[1].tls.peer.cert
certificate-key of calico-etcd-<podname>-node2-peer.values.nodes[1].tls.peer.key
certificate of calico-etcd-<podname>-node3.values.nodes[2].tls.client.cert
certificate-key calico-etcd-<podname>-node3.values.nodes[2].tls.client.key
certificate of calico-etcd-<podname>-node3-peer.values.nodes[2].tls.peer.cert
certificate-key of calico-etcd-<podname>-node3-peer.values.nodes[2].tls.peer.key

Undercloud Platform


Ceph


Openstack helm Infra

...

Parametersub-categoryDescriptionExample-Value
osh



region_nameThe region name to use. Typically Site name is provided.intel-pod10



PKI-Catalog

Parametersub-category-1sub-category-2DescriptionExample Value
certificate_authorities




description



certificates




document_name



description



common_name



hosts



groups

keypairs




name



description


...