Deduplicate networking definitions inside of airshipctl functions, and make the values driveable via a catalogue. Changes: * Removed BMO patches at site level; drive through catalogue instead. * Added separate entrypoints for ephemeral & target site-level. catalogue/networking overrides. Ephemeral's kustomizes target's. * Generalized the commonHostNetworking catalogue into a section in the overall networking catalogue. * Cleaned up catalogue use in general. * Got rid of some ill-formed Type-level phase definition. We should go back soon and define proper Type-level phases. Change-Id: Iff96ccdcf7ebde4ae55e2b1a9d25dd1cdca0d2c8 Relates-To: https://github.com/airshipit/airshipctl/issues/315
1.8 KiB
Function: hostgenerator-m3
This function constructs a collection of Metal3 BareMetalHost resources, along with associated configuration Secrets. It solves for a couple of things:
- pulling the nitty gritty details for generating BMH into one reusable place,
- allowing the site-specific details to be filled in via catalogues of values
This function leverages a couple of different plugins in sequence: The airshipctl Replacement plugin, which pulls the site-specific data from the catalogue documents into a Templater plugin configuration; and then the airshipctl Templater plugin, which generates a variable number of BMHs in a data-driven fashion.
To use this function, do the following:
-
Supply a
networking
catalogue, which outlines things that are typically common across hosts in a site, such as networking interfaces, DNS servers, and other networking info. Example:manifests/type/gating/shared/catalogues/common-networking.yaml
-
Supply a
host-catalogue
, which contains host-specific data, such as IP addresses and BMC information. Example:manifests/site/test-site/shared/catalogues/hosts.yaml
-
Supply a
host-generation-catalogue
for eachphase
that needs to deploy one or more BMHs. This catalogue simply lists the specific hosts that should be deployed during that phase. Example:manifests/site/test-site/ephemeral/bootstrap/hostgenerator/host-generation.yaml
-
If any per-host changes need to be made, they can be layered on top as site- or phase-specific Kustomize patches against the generated documents. E.g, if one host has a different network interface name, or if different details need to be used during ISO bootstrapping and normal deployment. Example:
manifests/site/test-site/ephemeral/bootstrap/baremetalhost.yaml