diff --git a/ansible/inventory/group_vars/all/bifrost b/ansible/inventory/group_vars/all/bifrost index e151d44fcc996e9cb08d17a29edbc611a8ee606a..b2d91628913d2c6175889612d3e46befe67975fb 100644 --- a/ansible/inventory/group_vars/all/bifrost +++ b/ansible/inventory/group_vars/all/bifrost @@ -68,6 +68,10 @@ kolla_bifrost_deploy_image_filename: "deployment_image.qcow2" # Default is none. kolla_bifrost_deploy_image_rootfs: +# Custom cloud-init user-data passed to deploy of the deployment image. +# Default is an empty string. +kolla_bifrost_deploy_image_user_data_content: '' + ############################################################################### # Ironic configuration. diff --git a/ansible/kolla-bifrost-hostvars.yml b/ansible/kolla-bifrost-hostvars.yml index c74a4f88bd1502a84ecc2aa25f3762ed6b2453ad..bb0ca2539d5b588d4cf1469580e347206b74a2aa 100644 --- a/ansible/kolla-bifrost-hostvars.yml +++ b/ansible/kolla-bifrost-hostvars.yml @@ -26,6 +26,7 @@ ipv4_nameserver: "{{ resolv_nameservers }}" network_mtu: "{{ admin_oc_net_name | net_mtu or '1500' }}" vlan_id: "{{ '' if admin_oc_net_name == provision_oc_net_name else (admin_oc_net_name | net_vlan) }}" + user_data_content: "{{ kolla_bifrost_deploy_image_user_data_content }}" tasks: - block: - name: Ensure the Bifrost host variables directory exists diff --git a/doc/source/configuration/reference/bifrost.rst b/doc/source/configuration/reference/bifrost.rst index b362f8f9912cfd14114ad388d49f52211d852a7c..7d72adaa044b575311222c6bc8eccd5cc740ac9e 100644 --- a/doc/source/configuration/reference/bifrost.rst +++ b/doc/source/configuration/reference/bifrost.rst @@ -195,6 +195,24 @@ The name of the root disk image to deploy can be configured via the Kayobe inventory. This can be used to provision different images across the overcloud. +It can be necessary to deploy overcloud hosts with custom settings which can be +configured during provision by the cloud-init user-data configured via the +``kolla_bifrost_deploy_image_user_data_content`` option. The defaults is an +empty string. + +.. code-block:: yaml + :caption: ``bifrost.yml`` + + kolla_bifrost_deploy_image_user_data_content: | + users: + name: myuser + sudo: ALL=(ALL) NOPASSWD:ALL + shell: /bin/bash + passwd: <HASH_OF_MY_PASSWORD> + lock_passwd: false + + timezone: "Europe/Paris" + While only a single disk image can be built with Bifrost, starting from the Yoga 12.0.0 release, Kayobe supports building multiple disk images directly through Diskimage builder. Consult the :ref:`overcloud host disk image build diff --git a/etc/kayobe/bifrost.yml b/etc/kayobe/bifrost.yml index 992451701a867c0c3e61834262ec040f8671acfd..18511afbfd9c700114113bf949e4ce1e3e8295b6 100644 --- a/etc/kayobe/bifrost.yml +++ b/etc/kayobe/bifrost.yml @@ -69,6 +69,10 @@ # Default is none. #kolla_bifrost_deploy_image_rootfs: +# Custom cloud-init user-data passed to deploy of the deployment image. +# Default is an empty string. +#kolla_bifrost_deploy_image_user_data_content: + ############################################################################### # Ironic configuration. diff --git a/releasenotes/notes/add-custom-user-data-content-d188c7c197b50acb.yaml b/releasenotes/notes/add-custom-user-data-content-d188c7c197b50acb.yaml new file mode 100644 index 0000000000000000000000000000000000000000..748e81c1deaefa460ba947a7fbcb1ab6915f9f70 --- /dev/null +++ b/releasenotes/notes/add-custom-user-data-content-d188c7c197b50acb.yaml @@ -0,0 +1,6 @@ +--- +features: + - | + Adds a new ``kolla_bifrost_deploy_image_user_data_content`` variable used + to define the custom user_data content used by the cloud-init for overcloud + provision.