It is possible to rebuild the pre-built tinyipa image available at tarballs.openstack.org to make it usable with ansible-deploy driver. The rebuild is rather fast, and only downloads 2 packages from TC mirrors (SSH server and dependencies). Change-Id: Ie39ce67dc93e7d53bf75937c7defacafad5fbfcf Related-Bug: #1526308
TinyIPA image compatible with Ansible-deploy driver
It is possible to rebuild the pre-built tinyipa ramdisk available from http://tarballs.openstack.org/ironic-python-agent/tinyipa to make it usable with Ansible-deploy driver.
Rebuilding TinyIPA
- Run the provided
rebuild-tinyipa.sh
script, set environment variables as explained in Build options. - Running this script will create a rebuilt ramdisk as
ansible-<original-tinyipa-ramdisk-name>
. That file must be uploaded to Glance as ARI image.- If tinyipa kernel is not in Glance yet, an appropriate version can be downloaded from tarballs.openstack.org and uploaded to Glance as AKI image.
- Update nodes that use
*_ansible
driver:- Assign ramdisk uploaded in the previous step as
driver_info/deploy_ramdisk
. - The kernel image created during TinyIPA build
(
tinyipa[-branch_name].vmlinuz
) should be used asdriver_info/deploy_kernel
if not set yet. - Set
tc
asdriver_info/ansible_deploy_user
.- If you have used a custom
SSH_PUBLIC_KEY
specify it asdriver_info/ansible_deploy_key_file
- If you have used a custom
- Ensure that the private SSH key file has correct
600
or400
exclusive permissions for the user running the ironic-conductor process.
- Assign ramdisk uploaded in the previous step as
- You can also assign the ramdisk created to other nodes that use
IPA
-based ramdisks asdriver_info/deploy_ramdisk
to have a unified deploy image for all nodes. It should work for them the same as original tinyipa ramdisk.
Build options
If rebuilding an existing tinyipa ramdisk file, set the
TINYIPA_RAMDISK_FILE
environment variable to absolute path to this file before running this script:export TINYIPA_RAMDISK_FILE=</full/path/to/tinyipa-ramdisk-file>
When not provided with existing file, this script will rebuild the tinyipa master branch build. To use a stable branch, set
BRANCH_PATH
environment variable (master
by default) before running the rebuild script accordingly. Branch names for stable releases must be in the formstable-<release>
, for example:export BRANCH_PATH=stable-newton
Consult https://tarballs.openstack.org/ironic-python-agent/tinyipa/files/ for currently available versions.
By default, the script will bake
id_rsa
orid_dsa
public SSH keys of the user running the build into the ramdisk as authorized_keys fortc
user. To provide a custom key, set absolute path to it asSSH_PUBLIC_KEY
environment variable before running this script:export SSH_PUBLIC_KEY=<path-to-public-ssh-key>
Using Makefile
For simplified configuration, a Makefile is provided to use
make
for some standard operations.
- make
-
will install required dependencies and run the
rebuild-tinyipa
script without arguments, downloading and rebuilding the image available at https://tarballs.openstack.org All customizations through environment variables still apply. - make clean
-
will cleanup temporary files and images created during build