Skip to content
Snippets Groups Projects
Commit 6b4f180a authored by Mark Goddard's avatar Mark Goddard Committed by Pierre Riteau
Browse files

Support installing packages in IPA images

Diskimage builder supports specifying a list of packages to install via
-p. We currently support this for the root image, but not IPA images.

This change adds a new configuration option, 'ipa_build_dib_packages',
that should be a list of additional packages to install in locally built
IPA images. This affects the following commands:

kayobe seed deployment image build
kayobe overcloud deployment image build

This depends on
https://github.com/stackhpc/ansible-role-os-images/pull/25.

Also adds an example to the documentation for the equivalent option for
root image.

Change-Id: I04191d9541894b6a264e966c9ecb1056e0edade4
Story: 2006855
Task: 37446
parent 8c01771e
No related branches found
No related tags found
No related merge requests found
...@@ -56,6 +56,9 @@ ipa_build_dib_env: > ...@@ -56,6 +56,9 @@ ipa_build_dib_env: >
# stackhpc.os-images role for usage. # stackhpc.os-images role for usage.
ipa_build_dib_git_elements: [] ipa_build_dib_git_elements: []
# List of DIB packages to install. Default is none.
ipa_build_dib_packages: []
############################################################################### ###############################################################################
# Ironic Python Agent (IPA) images configuration. # Ironic Python Agent (IPA) images configuration.
......
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
- name: "{{ ipa_image_name }}" - name: "{{ ipa_image_name }}"
elements: "{{ ipa_build_dib_elements }}" elements: "{{ ipa_build_dib_elements }}"
env: "{{ ipa_build_dib_env }}" env: "{{ ipa_build_dib_env }}"
packages: "{{ ipa_build_dib_packages }}"
# Avoid needing to install qemu-img for qcow2 image. # Avoid needing to install qemu-img for qcow2 image.
type: raw type: raw
os_images_git_elements: "{{ ipa_build_dib_git_elements }}" os_images_git_elements: "{{ ipa_build_dib_git_elements }}"
......
...@@ -27,6 +27,7 @@ ...@@ -27,6 +27,7 @@
- name: "{{ ipa_image_name }}" - name: "{{ ipa_image_name }}"
elements: "{{ ipa_build_dib_elements }}" elements: "{{ ipa_build_dib_elements }}"
env: "{{ ipa_build_dib_env }}" env: "{{ ipa_build_dib_env }}"
packages: "{{ ipa_build_dib_packages }}"
# Avoid needing to install qemu-img for qcow2 image. # Avoid needing to install qemu-img for qcow2 image.
type: raw type: raw
os_images_git_elements: "{{ ipa_build_dib_git_elements }}" os_images_git_elements: "{{ ipa_build_dib_git_elements }}"
......
...@@ -167,6 +167,20 @@ Alternatively, the :diskimage-builder-doc:`dynamic-login element ...@@ -167,6 +167,20 @@ Alternatively, the :diskimage-builder-doc:`dynamic-login element
<elements/dynamic-login/README>` can be used to authorize SSH keys by appending <elements/dynamic-login/README>` can be used to authorize SSH keys by appending
them to the kernel arguments. them to the kernel arguments.
Example: Installing a package
-----------------------------
It can be necessary to install additional packages in the root disk image.
Rather than needing to write a custom DIB element, we can use the
``kolla_bifrost_dib_packages`` variable. For example, to install the
``biosdevname`` package:
.. code-block:: yaml
:caption: ``ipa.yml``
kolla_bifrost_dib_packages:
- "biosdevname"
Ironic configuration Ironic configuration
==================== ====================
......
...@@ -66,6 +66,8 @@ image build``. ...@@ -66,6 +66,8 @@ image build``.
List of git repositories containing Diskimage Builder (DIB) elements. See List of git repositories containing Diskimage Builder (DIB) elements. See
`stackhpc.os-images <https://galaxy.ansible.com/stackhpc/os-images>`__ role `stackhpc.os-images <https://galaxy.ansible.com/stackhpc/os-images>`__ role
for usage. Default is none. for usage. Default is none.
``ipa_build_dib_packages``
List of DIB packages to install. Default is none.
Example: Building IPA images locally Example: Building IPA images locally
------------------------------------ ------------------------------------
...@@ -156,6 +158,20 @@ In this example the ``master`` branch of ...@@ -156,6 +158,20 @@ In this example the ``master`` branch of
https://git.example.com/custom-dib-elements would have a top level ``elements`` https://git.example.com/custom-dib-elements would have a top level ``elements``
directory, containing a ``my-element`` directory for the element. 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:
.. code-block:: yaml
:caption: ``ipa.yml``
ipa_build_dib_packages:
- "biosdevname"
Ironic Python Agent (IPA) images configuration Ironic Python Agent (IPA) images configuration
============================================== ==============================================
......
...@@ -47,6 +47,9 @@ ...@@ -47,6 +47,9 @@
# stackhpc.os-images role for usage. # stackhpc.os-images role for usage.
#ipa_build_dib_git_elements: #ipa_build_dib_git_elements:
# List of DIB packages to install. Default is none.
#ipa_build_dib_packages:
############################################################################### ###############################################################################
# Ironic Python Agent (IPA) images configuration. # Ironic Python Agent (IPA) images configuration.
......
---
features:
- |
Adds support for installing packages in locally built Ironic Python Agent
(IPA) images via the ``ipa_build_dib_packages`` variable. See `story
2006855 <https://storyboard.openstack.org/#!/story/2006855>`__ for details.
...@@ -30,7 +30,7 @@ ...@@ -30,7 +30,7 @@
- src: stackhpc.mellanox-switch - src: stackhpc.mellanox-switch
version: v1.0.0 version: v1.0.0
- src: stackhpc.os-images - src: stackhpc.os-images
version: v1.4.0 version: v1.6.0
- src: stackhpc.os-ironic-state - src: stackhpc.os-ironic-state
version: v1.1.0 version: v1.1.0
- src: stackhpc.os-networks - src: stackhpc.os-networks
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment