This allows us to add configuration scenarios. Change-Id: Id636f78c61237fb27fa65fa3d4b3fc1a4cf0ba6a Story: 2004360 Task: 40777
13 KiB
Ironic Python Agent (IPA)
This section covers configuration of Ironic Python Agent (IPA) which
is used by Ironic and Ironic Inspector to deploy and inspect bare metal
nodes. This is used by the Bifrost services that run on the seed host,
and also by Ironic and Ironic Inspector services running in the
overcloud for bare metal compute, if enabled
(kolla_enable_ironic
is true
). IPA
configuration is typically applied in
${KAYOBE_CONFIG_PATH}/ipa.yml
. Consult the IPA documentation <>
for
full details of IPA usage and configuration.
Ironic Python Agent (IPA) image build configuration
Note
This section may be skipped if not building IPA images locally
(ipa_build_images
is false
).
The following options cover building of IPA images via
Diskimage-builder (DIB). Consult the Diskimage-builder documentation <>
for full details.
The default configuration builds a CentOS 7 ramdisk image which includes the upstream IPA source code, and has a serial console enabled.
The images are built for Bifrost via
kayobe seed deployment image build
, and for Ironic in the
overcloud (if enabled) via
kayobe overcloud deployment image build
.
ipa_build_images
-
Whether to build IPA images from source. Default is
False
. ipa_build_source_url
-
URL of IPA source repository. Default is https://opendev.org/openstack/ironic-python-agent
ipa_build_source_version
-
Version of IPA source repository. Default is
{{ openstack_branch }}
. ipa_builder_source_url
-
URL of IPA builder source repository. Default is https://opendev.org/openstack/ironic-python-agent-builder
ipa_builder_source_version
-
Version of IPA builder source repository. Default is
master
. ipa_build_dib_elements_default
-
List of default Diskimage Builder (DIB) elements to use when building IPA images. Default is
["centos", "enable-serial-console", "ironic-python-agent-ramdisk"]
. ipa_build_dib_elements_extra
-
List of additional Diskimage Builder (DIB) elements to use when building IPA images. Default is empty.
ipa_build_dib_elements
-
List of Diskimage Builder (DIB) elements to use when building IPA images. Default is combination of
ipa_build_dib_elements_default
andipa_build_dib_elements_extra
. ipa_build_dib_env_default
-
Dictionary of default environment variables to provide to Diskimage Builder (DIB) during IPA image build. Default is
{"DIB_REPOLOCATION_ironic_agent": "{{ ipa_build_source_url }}", "DIB_REPOREF_ironic_agent": "{{ ipa_build_source_version }}"}
. ipa_build_dib_env_extra
-
Dictionary of additional environment variables to provide to Diskimage Builder (DIB) during IPA image build. Default is empty.
ipa_build_dib_env
-
Dictionary of environment variables to provide to Diskimage Builder (DIB) during IPA image build. Default is a combination of
ipa_build_dib_env_default
andipa_build_dib_env_extra
. ipa_build_dib_git_elements_default
-
List of default git repositories containing Diskimage Builder (DIB) elements. See stackhpc.os-images role for usage. Default is one item for IPA builder.
ipa_build_dib_git_elements_extra
-
List of additional git repositories containing Diskimage Builder (DIB) elements. See stackhpc.os-images role for usage. Default is none.
ipa_build_dib_git_elements
-
List of git repositories containing Diskimage Builder (DIB) elements. See stackhpc.os-images role for usage. Default is combination of
ipa_build_dib_git_elements_default
andipa_build_dib_git_elements_extra
. ipa_build_dib_packages
-
List of DIB packages to install. Default is none.
Example: Building IPA images locally
To build IPA images locally:
ipa_build_images: true
Example: Installing IPA from a custom git repository
To install IPA from a custom git repository:
ipa_source_url: https://git.example.com/ironic-python-agent
ipa_source_version: downstream
Example: Adding an element
In the following example, we extend the list of DIB elements to add
the mellanox element <elements/mellanox/README>
,
which can be useful for inspecting hardware with Mellanox InfiniBand
NICs.
ipa_build_dib_elements_extra:
- "mellanox"
Example: Configuring a development user account
Warning
A development user account should not be used in production.
When debugging a failed deployment, it can sometimes be necessary to
allow access to the image via a preconfigured user account with a known
password. This can be achieved via the devuser
<elements/devuser/README>
element.
This example shows how to add the devuser
element, and
configure a username and password for an account that has passwordless
sudo:
ipa_build_dib_elements_extra:
- "devuser"
ipa_build_dib_env_extra:
DIB_DEV_USER_USERNAME: "devuser"
DIB_DEV_USER_PASSWORD: "correct horse battery staple"
DIB_DEV_USER_PWDLESS_SUDO: "yes"
Alternatively, the dynamic-login element
<elements/dynamic-login/README>
can be used to authorize
SSH keys by appending them to the kernel arguments.
Further information on troubleshooting IPA can be found here <admin/troubleshooting>
.
Example: Configuring custom DIB elements
Sometimes it is useful to use custom DIB elements that are not shipped with DIB itself. This can be done by sharing them in a git repository.
ipa_build_dib_elements_extra:
- "my-element"
ipa_build_dib_git_elements:
- repo: "https://git.example.com/custom-dib-elements"
local: "{{ source_checkout_path }}/custom-dib-elements"
version: "master"
elements_path: "elements"
In this example the master
branch of https://git.example.com/custom-dib-elements
would have a top level elements
directory, containing a
my-element
directory for the element.
Example: Installing a package
It can be necessary to install additional packages in the IPA image.
Rather than needing to write a custom DIB element, we can use the
ipa_build_dib_packages
variable. For example, to install
the biosdevname
package:
ipa_build_dib_packages:
- "biosdevname"
Ironic Python Agent (IPA) images configuration
Note
If building IPA images locally (ipa_build_images
is
true
) this section can be skipped.
The following options configure the source of Ironic Python Agent
images for inspection and deployment. Consult the Ironic Python
Agent documentation <>
for full details.
ipa_images_upstream_url_suffix
-
Suffix of upstream Ironic deployment image files. Default is based on
{{ openstack_branch }}
. ipa_images_kernel_name
-
Name of Ironic deployment kernel image to register in Glance. Default is
ipa.kernel
. ipa_kernel_upstream_url
-
URL of Ironic deployment kernel image to download. Default is
https://tarballs.openstack.org/ironic-python-agent/dib/files/ipa-centos8{{ ipa_images_upstream_url_suffix }}.kernel
. ipa_kernel_checksum_url
-
URL of checksum of Ironic deployment kernel image. Default is
{{ ipa_kernel_upstream_url }}.{{ ipa_kernel_checksum_algorithm }}
. ipa_kernel_checksum_algorithm
-
Algorithm of checksum of Ironic deployment kernel image. Default is
sha256
. ipa_images_ramdisk_name
-
Name of Ironic deployment ramdisk image to register in Glance. Default is
ipa.initramfs
. ipa_ramdisk_upstream_url
-
URL of Ironic deployment ramdisk image to download. Default is
https://tarballs.openstack.org/ironic-python-agent/dib/files/ipa-centos8{{ ipa_images_upstream_url_suffix }}.initramfs
. ipa_ramdisk_checksum_url
-
URL of checksum of Ironic deployment ramdisk image. Default is
{{ ipa_ramdisk_upstream_url }}.{{ ipa_ramdisk_checksum_algorithm }}
. ipa_ramdisk_checksum_algorithm
-
Algorithm of checksum of Ironic deployment ramdisk image. Default is
sha256
.
Ironic Python Agent (IPA) deployment configuration
The following options configure how IPA operates during deployment and inspection.
ipa_collect_lldp
-
Whether to enable collection of LLDP TLVs. Default is
True
. ipa_collectors_default
-
Note
extra-hardware
is not currently included as it requires a ramdisk with thehardware
python module installed.List of default inspection collectors to run. Default is
["default", "logs", "pci-devices"]
. ipa_collectors_extra
-
List of additional inspection collectors to run. Default is none.
ipa_collectors
-
List of inspection collectors to run. Default is a combination of
ipa_collectors_default
andipa_collectors_extra
. ipa_benchmarks_default
-
List of default inspection benchmarks to run. Default is
["cpu", "disk", "ram"]
. ipa_benchmarks_extra
-
List of extra inspection benchmarks to run. Default is none.
ipa_benchmarks
-
Note
The
extra-hardware
collector must be enabled in order to execute benchmarks during inspection.List of inspection benchmarks to run. Default is a combination of
ipa_benchmarks_default
andipa_benchmarks_extra
. ipa_kernel_options_default
-
List of default kernel parameters for Ironic python agent. Default includes
ipa-collect-lldp
,ipa-inspection-collectors
andipa-inspection-benchmarks
, with arguments taken fromipa_collect_lldp
,ipa_collectors
andipa_benchmarks
. ipa_kernel_options_extra
-
List of additional kernel parameters for Ironic python agent. Default is none.
ipa_kernel_options
-
List of kernel parameters for Ironic python agent. Default is a combination of
ipa_kernel_options_default
andipa_kernel_options_extra
.
Example: Adding the
extra-hardware
collector
Note
The hardware
Python package has dropped support for
Python 2. If you are using an IPA image that uses Python 2 by default,
for example CentOS 7, you will need to use a version of the
hardware
package that is no greater than
0.23.x
. You can specify the version using the
DIB_IPA_HARDWARE_VERSION
environment variable. This can be
added to the ipa_build_dib_env_extra
dictionary in
${KAYOBE_CONFIG_PATH}/ipa.yml
. For example:
DIB_IPA_HARDWARE_VERSION: "0.23.0"
.
The extra-hardware
collector may be used to collect
additional information about hardware during inspection. It is also a
requirement for running benchmarks. This collector depends on the Python
hardware package, which
is not installed in IPA images by default.
The following example enables the extra-hardware
collector:
ipa_collectors_extra:
- "extra-hardware"
The StackHPC
image elements git repository provides an
ipa-extra-hardware
element which may be used to install
this package. It may be used as follows if building an IPA image
locally:
ipa_build_dib_elements_extra:
- "ipa-extra-hardware"
ipa_build_dib_git_elements:
- repo: "https://github.com/stackhpc/stackhpc-image-elements"
local: "{{ source_checkout_path }}/stackhpc-image-elements"
version: "master"
elements_path: "elements"
ipa_build_dib_env_extra:
# This is to workaround the fact that pip > 10 will produce an error if
# you try and uninstall a distuils installed package. Previous versions
# would remove the metadata only - leaving the code intact, see:
# https://bugs.launchpad.net/diskimage-builder/+bug/1768135
DIB_INSTALLTYPE_pip_and_virtualenv: package
Example: Passing additional kernel arguments to IPA
The following example shows how to pass additional kernel arguments to IPA:
ipa_kernel_options_extra:
- "foo=bar"