Addition of dynamic enrollment and deployment playbooks

Adding dynamic enrollment and deployment playbooks that leverage the
dynamic inventory functionality.  Additionally updated the README
to represent these newer playbooks.

Change-Id: I072b0d053048843521c4258655c212399a96d83f
This commit is contained in:
Julia Kreger 2015-06-19 17:55:51 -04:00
parent 7efb69cdc7
commit a170e0c37d
3 changed files with 48 additions and 13 deletions

View File

@ -198,9 +198,17 @@ An example file can be found at inventory/baremetal.csv.example.
How this works?
---------------
The enroll.yaml playbook requires a variable (baremetal_csv_file) be set or
passed into the playbook execution. NOTE: This MUST be the full path to the
CSV file to be consumed by the Ansible playbooks and loaded into ironic.
Utilizing the dynamic inventory module, enrollment is as simple as setting
the BIFROST_INVENTORY_SOURCE environment variable to your inventory data
source, and then executing the the enrollment playbook.::
export BIFROST_INVENTORY_SOURCE=/tmp/baremetal.json
ansible-playbook -vvvv -i inventory/bifrost_inventory.py enroll-dynamic.yaml
The legacy enroll.yaml playbook requires a variable (baremetal_csv_file) be
set or passed into the playbook execution. NOTE: This MUST be the full path
to the CSV file to be consumed by the Ansible playbooks and loaded into
ironic.
Example::
@ -216,18 +224,20 @@ split into three separate playbooks based up the setting of ipmi_bridging.
Hardware Deployment
===================
Requirements:
- The baremetal.csv file that was utilized for the enrollment process.
How this works?
---------------
The deploy.yaml playbook is intended to create configdrives for servers, and
initiate the node deployments through Ironic. IPs are injected into the config
drive and are statically assigned.
After the nodes are enrolled, they can be deployed upon. Bifrost is geared to
utilize configuration drives to convey basic configuration information to the
each host. This case is the same between the newer deploy-dynamic.yaml
playbook and the older legacy deploy.yaml playbook.
Example::
To utilize the newer dynamic inventory based deployment::
export BIFROST_INVENTORY_SOURCE=/tmp/baremetal.json
ansible-playbook -vvvv -i inventory/bifrost_inventory.py enroll-dynamic.yaml
To utilize the legacy csv file based playbook::
ansible-playbook -i inventory/localhost -vvvv deploy.yaml -e baremetal_csv_file=inventory/baremetal.csv
@ -246,8 +256,8 @@ Note:
- Cleaning mode is explicitly disabled in the test-bifrost.yaml playbook due to the fact that is an IO intensive operation that can take a great deal of time.
Testing with Virtual Machines
=============================
Legacy - Testing with Virtual Machines
======================================
Bifrost supports using virtual machines to emulate the hardware. All of the
steps mentioned above are mostly the same.

View File

@ -0,0 +1,13 @@
---
- hosts: localhost
connection: local
name: "Collect facts"
sudo: no
gather_facts: yes
- hosts: baremetal
name: "Create configuration drive files and deploy machines from inventory"
sudo: no
connection: local
roles:
- role: bifrost-configdrives-dynamic
- role: bifrost-deploy-nodes-dynamic

View File

@ -0,0 +1,12 @@
---
- hosts: localhost
connection: local
name: "Collect facts"
sudo: no
gather_facts: yes
- hosts: baremetal
connection: local
name: "Enroll hardware from inventory into Ironic"
sudo: no
roles:
- role: ironic-enroll-dynamic