Jump to: navigation, search

Ironic/TripleO

< Ironic
Revision as of 18:24, 14 February 2014 by Devananda (talk | contribs) (copied from /Ironic)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Using Ironic with TripleO

In this section, we will go over how to set up Ironic within the TripleO enviroment.

Note: TripleO is under rapid development and may invalidate this walk thru.

If not familiar with TripleO and / or have not used the DiskImage-Builder (DIB) tool before, please read and familiarize yourself with the TripleO story. Here are some good starting points:

Please follow TripleO's Devtest-Doc up to the devtest_undercloud section.


Build undercloud containing Ironic

We need to modify step #1 of devtest_undercloud-walkthru to include the Ironic services, and to switch Nova from using the nova.virt.baremetal driver to instead use the nova.virt.ironic driver.

# Note that rev 21 was current at the time of this writing. You may need to update this revision number
NOVA_PATCH_REV=21
cd $TRIPLEO_ROOT
export UNDERCLOUD_DIB_EXTRA_ARGS="nova-ironic"
export DIB_REPOLOCATION_nova=https://review.openstack.org/openstack/nova
export DIB_REPOREF_nova=refs/changes/28/51328/$NOVA_PATCH_REV

Proceed until step #3 of devtest_undercloud-walkthru.

Heat template

Instead of building the undercloud-vm.yaml file, we want to build the undercloud-vm-ironic.yaml file:

make -C $TRIPLEO_ROOT/tripleo-heat-templates undercloud-vm-ironic.yaml

This template requires slightly different parameters, so use this command to deploy your undercloud:

heat stack-create -f $TRIPLEO_ROOT/tripleo-heat-templates/undercloud-vm-ironic.yaml \
-P "AdminToken=${UNDERCLOUD_ADMIN_TOKEN};\
AdminPassword=${UNDERCLOUD_ADMIN_PASSWORD};\
GlancePassword=${UNDERCLOUD_GLANCE_PASSWORD};\
HeatPassword=${UNDERCLOUD_HEAT_PASSWORD};\
NeutronPassword=${UNDERCLOUD_NEUTRON_PASSWORD};\
NovaPassword=${UNDERCLOUD_NOVA_PASSWORD};\
BaremetalArch=${NODE_ARCH};\
IronicPassword=${UNDERCLOUD_IRONIC_PASSWORD}" \
undercloud

Continue devtest_undercloud-walkthru

Continue to follow the devtest_undercloud-walkthru up through step #9.

Register the Ironic service

After step #9, register the Ironic service with keystone.

PASSWORD=$UNDERCLOUD_IRONIC_PASSWORD register-endpoint -r "regionOne" -d "Ironic Service" ironic baremetal http://$UNDERCLOUD_IP:6385

In devtest_undercloud-walkthru's step #10, nodes are registered to the undercloud's nova-baremetal and not Ironic. Instead of that, we'll create a 'baremetal' node and register it with ironic, via the undercloud.

Allow Ironic's SSH driver to connect to your local machine:

ssh heat-admin@$UNDERCLOUD_IP "cat /opt/stack/boot-stack/ironic-ssh-power-key.pub" >> ~/.ssh/authorized_keys

Copy the Ironic API credentials to your local machine:

ssh heat-admin@$UNDERCLOUD_IP -- 'sudo cat /root/stackrc' > $TRIPLEO_ROOT/tripleo-incubator/ironicrc
sed -i "s/localhost/$UNDERCLOUD_IP/" $TRIPLEO_ROOT/tripleo-incubator/ironicrc
source $TRIPLEO_ROOT/tripleo-incubator/ironicrc

Create an emulated baremetal node

This will create a 'baremetal' node:

export UNDERCLOUD_MAC=$(create-nodes $NODE_CPU $NODE_MEM $NODE_DISK $NODE_ARCH 1)

Use the ironic client to enroll the baremetal node:

HOST_IP=$(ip addr show virbr0 | grep inet | awk '{print $2}' | sed 's/\/[0-9]*//')
CHASSIS=$(ironic chassis-create -d TestChassis | grep uuid | awk '{print $4}')
NODE=$(ironic node-create -c $CHASSIS -d pxe_ssh | grep ' uuid ' | awk '{print $4}')
ironic port-create -n $NODE -a $UNDERCLOUD_MAC 
ironic node-update $NODE add \
 driver_info/ssh_virt_type=virsh \
 driver_info/ssh_address=$HOST_IP \
 driver_info/ssh_key_filename=/opt/stack/boot-stack/ironic-ssh-power-key \
 driver_info/ssh_username=$(whoami)

Confirm everything is enrolled and correct:

ironic node-show $NODE

You can now control the power state of this node with this command:

ironic node-set-power-state $NODE [on|off|reboot]