Jump to: navigation, search

Difference between revisions of "Ironic"

(Test it: deleting this section)
 
(98 intermediate revisions by 24 users not shown)
Line 1: Line 1:
 +
= OpenStack Bare Metal Provisioning Program =
  
{| border="1" cellpadding="2" cellspacing="0"
+
OpenStack bare metal provisioning a.k.a '''Ironic''' is an integrated OpenStack program which aims to provision bare metal machines instead of virtual machines, forked from the Nova baremetal driver. It is best thought of as a bare metal hypervisor API and a set of plugins which interact with the bare metal hypervisors. By default, it will use PXE and IPMI in order to provision and turn on/off machines, but Ironic also supports vendor-specific plugins which may implement additional functionality. For a general overview please see: [https://docs.openstack.org/ironic/latest/user/index.html Introduction to Ironic].
| [https://github.com/openstack/ironic Source code
+
 
 +
= Latest Documentation =
 +
 
 +
This wiki is updated by volunteers as time permits. For the latest documentation, it is highly advisable to refer to the project documentation which is generated from the embedded documentation. Please see: [https://docs.openstack.org/ironic/latest/ latest ironic documentation].
 +
 
 +
= Projects =
 +
 
 +
Ironic is governed by the OpenStack Technical Committee. The complete list of deliverables (and associated tags) that are officially under the Ironic umbrella is available [http://governance.openstack.org/reference/projects/ironic.html here].
 +
 
 +
Some of the deliverables (or projects) are described below.
 +
 
 +
== ironic ==
 +
 
 +
The '''ironic''' project includes the ironic-api and ironic-conductor processes.
 +
 
 +
{| border="1" cellpadding="2"
 +
| Official name
 +
| '''OpenStack Bare Metal Provisioning'''
 +
|-
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/ironic
 +
|-
 +
| Documentation
 +
| https://docs.openstack.org/ironic/latest/
 +
|-
 +
| Bug tracker
 +
| https://storyboard.openstack.org/#!/project/943
 +
|-
 +
| Feature tracker
 +
| https://storyboard.openstack.org/#!/project/943
 +
|-
 +
| Specifications
 +
| http://specs.openstack.org/openstack/ironic-specs
 +
|-
 +
| Weekly meetings
 +
| https://wiki.openstack.org/wiki/Meetings/Ironic
 +
|-
 +
| Testing
 +
| https://wiki.openstack.org/wiki/Ironic/Testing
 +
|-
 +
| Drivers
 +
| https://wiki.openstack.org/wiki/Ironic/Drivers
 +
|}
 +
 
 +
== python-ironicclient ==
 +
 
 +
'''python-ironicclient''' is a package that includes the python client and CLI.
 +
 
 +
{| border="1" cellpadding="2"
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/python-ironicclient
 +
|-
 +
| Bug tracker
 +
| https://storyboard.openstack.org/#!/project/959
 +
|-
 +
| Feature tracker
 +
| https://storyboard.openstack.org/#!/project/959
 +
|-
 +
| Documentation
 +
| https://docs.openstack.org/python-ironicclient/latest/
 +
|}
 +
 
 +
== ironic-python-agent ==
 +
 
 +
'''ironic-python-agent''' is a small python application that is meant to be embedded in a deployment ramdisk.
 +
 
 +
{| border="1" cellpadding="2"
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/ironic-python-agent
 +
|-
 +
| Bug tracker
 +
| https://storyboard.openstack.org/#!/project/947
 
|-
 
|-
| [https://review.openstack.org/#/q/status:open+project:openstack/ironic,n,z Code review board]
+
| Documentation
 +
| https://docs.openstack.org/ironic-python-agent/latest/
 
|-
 
|-
| [https://bugs.launchpad.net/ironic Bug tracker
+
| Wiki page
 +
| https://wiki.openstack.org/wiki/Ironic-python-agent
 +
|}
 +
 
 +
== ironic-inspector ==
 +
 
 +
'''ironic-inspector''' is a hardware introspection tool.
 +
 
 +
{| border="1" cellpadding="2"
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/ironic-inspector
 +
|-
 +
| Bug Tracker
 +
| https://storyboard.openstack.org/#!/project/944
 +
|-
 +
| Feature tracker
 +
| https://storyboard.openstack.org/#!/project/944
 +
|-
 +
| Documentation
 +
| https://docs.openstack.org/ironic-inspector/latest/
 +
|}
 +
 
 +
== bifrost ==
 +
 
 +
'''bifrost''' consists of Ansible play books for running Ironic standalone (without other OpenStack components).
 +
 
 +
{| border="1" cellpadding="2"
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/bifrost
 
|-
 
|-
| [https://blueprints.launchpad.net/ironic Blueprints]
+
| Bug tracker
 +
| https://storyboard.openstack.org/#!/project/941
 
|-
 
|-
| [http://docs.openstack.org/developer/ironic/ Developer docs]
+
| Documentation
 +
| https://docs.openstack.org/bifrost/latest/
 +
|}
 +
 
 +
== networking-baremetal ==
 +
 
 +
'''networking-baremetal''' is a Neutron plugin that covers bare metal use cases; it provides deep Ironic/Neutron integration.
 +
 
 +
{| border="1" cellpadding="2"
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/networking-baremetal
 
|-
 
|-
| [[Meetings/Ironic|Weekly meetings]]
+
| Bug tracker
 +
| https://storyboard.openstack.org/#!/project/955
 
|}
 
|}
  
__TOC__
+
== ironic-lib ==
  
= Ironic: Bare Metal provisioning for OpenStack =
+
'''ironic-lib''' is a common library of functions used exclusively by the projects under the [http://governance.openstack.org/reference/projects/ironic.html Ironic governance].
  
'''Ironic is under rapid initial development, forked from [[Baremetal|Nova's Baremetal driver.]]''' If you're looking for something that works today, go there :)
+
{| border="1" cellpadding="2"
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/ironic-lib
 +
|-
 +
| Bug tracker
 +
| https://storyboard.openstack.org/#!/project/946
 +
|-
 +
| Documentation
 +
| https://docs.openstack.org/ironic-lib/latest/
 +
|}
  
If you'd like to join the development, start by [http://docs.openstack.org/developer/ironic/ reading the developer docs here], and then join us in the  <code>#openstack-ironic</code> on [http://irc.freenode.net irc.freenode.net]!
+
== ironic-ui ==
  
=== Building Documentation Locally ===
+
'''ironic-ui''' is a horizon plugin for ironic.
  
If you want to build the ironic docs for yourself locally, follow these steps:
+
{| border="1" cellpadding="2"
 +
| Source code
 +
| https://git.openstack.org/cgit/openstack/ironic-ui
 +
|-
 +
| Bug Tracker
 +
| https://storyboard.openstack.org/#!/project/952
 +
|-
 +
| Documentation
 +
| https://docs.openstack.org/ironic-ui/latest/
 +
|}
 +
 
 +
= People =
  
create a vm
+
'''PTL''': Julia Kreger (TheJulia)
  #using vagrant 1.2.2 with a virtualbox backend
 
  vagrant init precise32
 
  #enable networking with the host
 
    vi Vagrantfile
 
    add
 
      config.vm.network :forwarded_port, guest: 80, host: 4567
 
  vagrant up
 
 
shell into the vm
 
  vagrant ssh
 
 
install dependencies
 
  sudo apt-get update
 
  sudo apt-get install -y git apache2 python-dev swig libssl-dev python-pip libmysqlclient-dev libxml2-dev libxslt-dev libxslt1-dev python-mysqldb libpq-dev
 
  sudo pip install virtualenv setuptools-git flake8 tox
 
  sudo easy_install nose
 
 
get the ironic repo
 
  cd ~
 
  git clone git://github.com/openstack/ironic.git
 
 
create a file enabling ironic.localhost in apache
 
  sudo vi /etc/apache2/sites-enabled/100-ironic
 
  # contents
 
  <VirtualHost *:80>
 
      ServerName ironic.localhost
 
      DocumentRoot /opt/source/ironic/doc/build/html
 
   
 
          <Directory /opt/source/ironic/doc/build/html>
 
                  Options Indexes FollowSymLinks MultiViews
 
                  AllowOverride None
 
                  Order allow,deny
 
                  allow from all
 
          </Directory>
 
  </VirtualHost>
 
  # change the DocumentRoot and the Directory to point the the ironic repo, if you are using
 
  # vagrant and the ironic repo is the the vagrant user's home directory the code is fine
 
 
create a venv inside the ironic repo
 
  cd ironic
 
  tox -evenv -- echo 'done'
 
 
activate the newly created venv
 
  source .tox/venv/bin/activate
 
 
from inside the venv
 
  python setup.py build_sphinx
 
  # as I run this I get 20 warnings, ignore the warnings
 
exit the venv
 
  deactivate
 
 
restart apache
 
  sudo service apache2 restart
 
 
on your host:
 
  add ironic.localhost to /etc/hosts with:
 
  sudo sed -i 's/\(127.0.0.1\s*localhost\)/\1 ironic.localhost/' /etc/hosts
 
 
point your browser to http://ironic.localhost:4567
 
 
You should be reading your newly build documentation.
 
  
=== Try it on Devstack ===
+
'''Core teams''': https://wiki.openstack.org/wiki/Ironic/CoreTeam
  
To install Ironic using Devstack follow the following steps:
+
'''Cross-project liaisons''': https://wiki.openstack.org/wiki/CrossProjectLiaisons
  
1. Obtain the latest copy of Devstack:
+
= Status =
  git clone git://github.com/openstack-dev/devstack.git
 
  
2. Go to the Devstack source tree and create a localrc file with at least the following options:
+
Ironic was first available as an incubated project in the "Icehouse" release. The following "Juno" release saw improved integration with Nova, as well as many stability and feature improvements. Ironic completed the project graduation review at the end of the "Juno" cycle, and began "Kilo" development cycle as an officially integrated OpenStack project.
  # Enable Ironic API and Ironic Conductor
 
  enable_service ir-api
 
  enable_service ir-cond
 
 
 
  # Enable Neutron which is required by Ironic and disable nova-network.
 
  disable_service n-net
 
  enable_service q-svc
 
  enable_service q-agt
 
  enable_service q-dhcp
 
  enable_service q-l3
 
  enable_service q-meta
 
  enable_service neutron
 
 
 
  # You can replace "password" with your own one.
 
  ADMIN_PASSWORD=password
 
  MYSQL_PASSWORD=password
 
  RABBIT_PASSWORD=password
 
  SERVICE_PASSWORD=password
 
  
3. Run installation of Devstack:
+
Release notes for Ironic are available at http://docs.openstack.org/releasenotes/ironic/.
  ./stack.sh
 
  
4. Wait until everything gets installed.
+
Information on the latest status of Ironic's test suite can be found here: https://wiki.openstack.org/wiki/Ironic/Testing.
  
5. Ironic API service is listening on http://YOUR_IP:6385
+
For a list of current drivers and the status of their CI testing, see the [https://wiki.openstack.org/wiki/Ironic/Drivers wiki page we maintain] and the [http://stackalytics.com/report/driverlog?project_id=openstack%2Fironic Stackalytics page which tracks third-party CI].
  
=== Using Disk Image Builder ===
+
= Etherpads =
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.
+
Our project teams frequently share ideas and coordinate by using etherpads, some of which stick around for a while. Those are listed here.
<br />
+
* [https://etherpad.openstack.org/p/IronicWhiteBoard General-purpose "white board"]
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:
+
* [https://etherpad.openstack.org/p/IronicReviewDay Coordination point during "review days"]
:* [https://github.com/openstack/tripleo-incubator/blob/master/README.md TripleO-ReadMe]
 
:* [http://docs.openstack.org/developer/tripleo-incubator/deploying.html Deploying-Doc]
 
:* [http://docs.openstack.org/developer/tripleo-incubator/devtest.html Devtest-Doc]
 
  
Please follow TripleO's [http://docs.openstack.org/developer/tripleo-incubator/devtest.html Devtest-Doc] up to the [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud] section.
+
= IRC =
<br />
 
  
==== Add Ironic to the undercloud ====
+
Discussion of the project also takes place in '''#openstack-ironic''' on irc.oftc.net. This is a great place to jump in and start your ironic adventure. The channel is very welcoming to new users - no question is a wrong question!
Before doing step #1 of [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru], Download the Nova-ironic, and modified Nova element from [https://github.com/NoBodyCam/ironic-element NobodyCam's-repo]. After downloading the elements replace TripleO's Nova element with the one just downloaded, and move the downloaded Nova-ironic element in to the ELEMENTS_PATH ($TRIPLEO_ROOT/tripleo-image-elements/elements). Then add 'ironic' argument to the disk-image-create command:
 
  
cd $TRIPLEO_ROOT
+
= Developers =
export UNDERCLOUD_DIB_EXTRA_ARGS="nova-ironic"
 
  
Then do step #1, $TRIPLEO_ROOT/diskimage-builder/bin/disk-image-create...
+
Guidelines for developers can be found here: https://wiki.openstack.org/wiki/Ironic/Developer_guidelines
 +
Please note that for any non-trivial change that is not a fix for a particular bug, you have to go through the [https://wiki.openstack.org/wiki/Ironic/Specs_Process specs review process]
  
: '''Note''': This will install Ironic and the Ironic command line client on the undercloud image. It will configure ironic.conf to use the undercloud's services. At this point it will NOT configure the undercloud to use Ironic's services.
 
  
==== Load Undercloud image ====
+
= Pixie Boots, the Ironic drummer bear =
Step #2 of [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru] loads the undercloud image containing Ironic you created above, into glance:
 
load-image $TRIPLEO_ROOT/undercloud.qcow2
 
  
==== Create the required passwords ====
+
Pixie Boots is the mascot of the "'''Bear Metal'''" Provisioning Program for OpenStack, a.k.a Ironic. It was drawn by [http://lucasgom.es Lucas Alvares Gomes] and two versions of it are available: One colored and one outlined. An icon shadowcut of pixie boots is also available, courtesy of [https://plus.google.com/u/0/+MichaelKrotscheck Michael Krotscheck]. Feel free to use the images to make t-shirts or any other paraphernalia.
Step #3 of the [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru] creates the required passwords for the undercloud.
 
setup-undercloud-passwords
 
source tripleo-undercloud-passwords
 
: '''Note''': until [https://review.openstack.org/#/c/59800 this-review] lands you will need to manually create the IRONIC password.
 
export UNDERCLOUD_IRONIC_PASSWORD=$(os-make-password)
 
  
==== Merge the Ironic and undercloud yaml files ====
+
High-resolution PNGs versions are available by clicking on the images below:
Step #4 of the [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru] needs to be modified to create required Ironic yaml file. Use the make command below to create the correct yaml file.
 
make -C $TRIPLEO_ROOT/tripleo-heat-templates undercloud-vm-ironic.yaml
 
: '''Note''': it will create the $TRIPLEO_ROOT/tripleo-heat-templates/undercloud-vm-ironic.yaml file.
 
  
==== Boot the Ironic undercloud image ====
+
<gallery>
Use the command below in place of [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru's] step #4 to spin up the undercloud! (It uses undercloud-vm-ironic.yaml instead of the tripleo-heat-templates/undercloud-vm.yaml and adds IronicPassword=${UNDERCLOUD_IRONIC_PASSWORD}.)
+
Ironic_mascot_color.png|Colored
+
Ironic_mascot_outline.png|Outlined
heat stack-create '''-f $TRIPLEO_ROOT/tripleo-heat-templates/undercloud-vm-ironic.yaml''' \
+
bear metal.svg|Icon
-P "PowerUserName=$(whoami);\
+
</gallery>
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
 
<br />
 
Once HEAT has finished its magic, "nova list" should show something like this:
 
+----------------------+------------------------------------+--------+------------+-------------+--------------------+
 
| ID                  | Name                              | Status | Task State | Power State | Networks          |
 
+----------------------+------------------------------------+--------+------------+-------------+--------------------+
 
| <UUID>              | undercloud-notcompute-bo7jyyewi3on | ACTIVE | None      | Running    | ctlplane=192.0.2.2 |
 
+----------------------+------------------------------------+--------+------------+-------------+--------------------+
 
This will be the Ironic node.
 
<br />
 
  
After doing step #5 of [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru's], you will be able to login to the undercloud node with ssh, use a command like this:
+
You can also download the Inkscape SVG vector file: [https://wiki.openstack.org/wiki/File:Ironic_mascot.svg Ironic_mascot.svg]
ssh heat-admin@$UNDERCLOUD_IP
 
:'''Note''': We included the stackuser element when we built our image so if you have console access you may also login on the console with " stack " as both username and password. Both users, "heat-admin" and "stack", have full sudo access.
 
  
==== Continue  [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru] ====
+
All images are licensed [http://creativecommons.org/licenses/by-sa/4.0/ CC BY-SA].
Continue to follow the [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru] up through step #8.
 
  
==== Install the Ironic client ====
+
Pixie Boots rockin': \m/ ʕ•͡ᴥ•ʔ \m/
  
NOTE: This is only necessary until tripleo-incubator/scripts/setup-clienttools includes python-ironicclient
+
= Misc. =
sudo pip install python-ironicclient
 
  
If you want to use the latest code in trunk, or need to test a specific client review, use a virtual environment:
+
* [[Ironic/IPv6|Ironic + IPv6]]
git clone https://git.openstack.org/openstack/python-ironicclient
 
cd python-ironicclient
 
tox -evenv -- echo done
 
source .tox/venv/bin/activate
 
# to test the code in a given review, just download it. No need to install.
 
git review -d XXXXX
 
  
==== Register the Ironic service ====
+
= Outside the OpenStack Bare Metal Provisioning Program =
After step #8, register the Ironic service with keystone.
 
PASSWORD=$UNDERCLOUD_IRONIC_PASSWORD register-endpoint -r "regionOne" -d "Ironic Service" ironic baremetal http://$UNDERCLOUD_IP:6385
 
  
In [http://docs.openstack.org/developer/tripleo-incubator/devtest_undercloud.html devtest_undercloud-walkthru's] step #9, 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.
+
== Out-of-tree Ironic drivers ==
  
This will create a 'baremetal' node:
+
Drivers that can be used with Ironic but that aren't in the [https://git.openstack.org/cgit/openstack/ironic ironic] repository, may be found in the [https://git.openstack.org/cgit/openstack/ironic-staging-drivers ironic-staging-drivers] repository.
export UNDERCLOUD_MAC=$(create-nodes $NODE_CPU $NODE_MEM $NODE_DISK $NODE_ARCH 1)
+
== Vendor-specific tools ==
  
Allow Ironic's SSH driver to connect to your local machine:
+
Third-party vendors are encouraged to share their tools/scripts which might help people using their hardware with '''ironic'''These tools are not maintained by the ironic core team and are not under the governance of the OpenStack Technical Committee. Vendors themselves should be contacted for features requests/bug fixes.
ssh heat-admin@$UNDERCLOUD_IP "cat /opt/stack/boot-stack/virtual-power-key.pub" >> ~/.ssh/authorized_keys
 
  ssh heat-admin@$UNDERCLOUD_IP "sudo chown ironic:ironic /opt/stack/boot-stack/virtual-power-key*"
 
  
Copy the Ironic API credentials to your local machine:
+
{| border="1" cellpadding="2"
ssh heat-admin@$UNDERCLOUD_IP -- 'sudo cat /root/stackrc' > $TRIPLEO_ROOT/tripleo-incubator/ironicrc
+
| Developer doc
sed -i "s/localhost/$UNDERCLOUD_IP/" $TRIPLEO_ROOT/tripleo-incubator/ironicrc
+
| https://wiki.openstack.org/wiki/Ironic/ThirdPartyVendorToolsDeveloperDoc
source $TRIPLEO_ROOT/tripleo-incubator/ironicrc
+
|-
 +
| List of third party vendor tools
 +
| https://wiki.openstack.org/wiki/Ironic/ThirdPartyVendorToolsList
 +
|}
  
Use the ''ironic'' client to add and configure 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/virtual-power-key \
 
  driver_info/ssh_username=$(whoami)
 
  
You can now control the power state of the 'baremetal' node with this command:
+
[[category: baremetal]]
ironic node-set-power-state $NODE on
+
[[category: ironic]]
ironic node-show $NODE
 

Latest revision as of 08:56, 31 May 2021

OpenStack Bare Metal Provisioning Program

OpenStack bare metal provisioning a.k.a Ironic is an integrated OpenStack program which aims to provision bare metal machines instead of virtual machines, forked from the Nova baremetal driver. It is best thought of as a bare metal hypervisor API and a set of plugins which interact with the bare metal hypervisors. By default, it will use PXE and IPMI in order to provision and turn on/off machines, but Ironic also supports vendor-specific plugins which may implement additional functionality. For a general overview please see: Introduction to Ironic.

Latest Documentation

This wiki is updated by volunteers as time permits. For the latest documentation, it is highly advisable to refer to the project documentation which is generated from the embedded documentation. Please see: latest ironic documentation.

Projects

Ironic is governed by the OpenStack Technical Committee. The complete list of deliverables (and associated tags) that are officially under the Ironic umbrella is available here.

Some of the deliverables (or projects) are described below.

ironic

The ironic project includes the ironic-api and ironic-conductor processes.

Official name OpenStack Bare Metal Provisioning
Source code https://git.openstack.org/cgit/openstack/ironic
Documentation https://docs.openstack.org/ironic/latest/
Bug tracker https://storyboard.openstack.org/#!/project/943
Feature tracker https://storyboard.openstack.org/#!/project/943
Specifications http://specs.openstack.org/openstack/ironic-specs
Weekly meetings https://wiki.openstack.org/wiki/Meetings/Ironic
Testing https://wiki.openstack.org/wiki/Ironic/Testing
Drivers https://wiki.openstack.org/wiki/Ironic/Drivers

python-ironicclient

python-ironicclient is a package that includes the python client and CLI.

Source code https://git.openstack.org/cgit/openstack/python-ironicclient
Bug tracker https://storyboard.openstack.org/#!/project/959
Feature tracker https://storyboard.openstack.org/#!/project/959
Documentation https://docs.openstack.org/python-ironicclient/latest/

ironic-python-agent

ironic-python-agent is a small python application that is meant to be embedded in a deployment ramdisk.

Source code https://git.openstack.org/cgit/openstack/ironic-python-agent
Bug tracker https://storyboard.openstack.org/#!/project/947
Documentation https://docs.openstack.org/ironic-python-agent/latest/
Wiki page https://wiki.openstack.org/wiki/Ironic-python-agent

ironic-inspector

ironic-inspector is a hardware introspection tool.

Source code https://git.openstack.org/cgit/openstack/ironic-inspector
Bug Tracker https://storyboard.openstack.org/#!/project/944
Feature tracker https://storyboard.openstack.org/#!/project/944
Documentation https://docs.openstack.org/ironic-inspector/latest/

bifrost

bifrost consists of Ansible play books for running Ironic standalone (without other OpenStack components).

Source code https://git.openstack.org/cgit/openstack/bifrost
Bug tracker https://storyboard.openstack.org/#!/project/941
Documentation https://docs.openstack.org/bifrost/latest/

networking-baremetal

networking-baremetal is a Neutron plugin that covers bare metal use cases; it provides deep Ironic/Neutron integration.

Source code https://git.openstack.org/cgit/openstack/networking-baremetal
Bug tracker https://storyboard.openstack.org/#!/project/955

ironic-lib

ironic-lib is a common library of functions used exclusively by the projects under the Ironic governance.

Source code https://git.openstack.org/cgit/openstack/ironic-lib
Bug tracker https://storyboard.openstack.org/#!/project/946
Documentation https://docs.openstack.org/ironic-lib/latest/

ironic-ui

ironic-ui is a horizon plugin for ironic.

Source code https://git.openstack.org/cgit/openstack/ironic-ui
Bug Tracker https://storyboard.openstack.org/#!/project/952
Documentation https://docs.openstack.org/ironic-ui/latest/

People

PTL: Julia Kreger (TheJulia)

Core teams: https://wiki.openstack.org/wiki/Ironic/CoreTeam

Cross-project liaisons: https://wiki.openstack.org/wiki/CrossProjectLiaisons

Status

Ironic was first available as an incubated project in the "Icehouse" release. The following "Juno" release saw improved integration with Nova, as well as many stability and feature improvements. Ironic completed the project graduation review at the end of the "Juno" cycle, and began "Kilo" development cycle as an officially integrated OpenStack project.

Release notes for Ironic are available at http://docs.openstack.org/releasenotes/ironic/.

Information on the latest status of Ironic's test suite can be found here: https://wiki.openstack.org/wiki/Ironic/Testing.

For a list of current drivers and the status of their CI testing, see the wiki page we maintain and the Stackalytics page which tracks third-party CI.

Etherpads

Our project teams frequently share ideas and coordinate by using etherpads, some of which stick around for a while. Those are listed here.

IRC

Discussion of the project also takes place in #openstack-ironic on irc.oftc.net. This is a great place to jump in and start your ironic adventure. The channel is very welcoming to new users - no question is a wrong question!

Developers

Guidelines for developers can be found here: https://wiki.openstack.org/wiki/Ironic/Developer_guidelines Please note that for any non-trivial change that is not a fix for a particular bug, you have to go through the specs review process


Pixie Boots, the Ironic drummer bear

Pixie Boots is the mascot of the "Bear Metal" Provisioning Program for OpenStack, a.k.a Ironic. It was drawn by Lucas Alvares Gomes and two versions of it are available: One colored and one outlined. An icon shadowcut of pixie boots is also available, courtesy of Michael Krotscheck. Feel free to use the images to make t-shirts or any other paraphernalia.

High-resolution PNGs versions are available by clicking on the images below:

You can also download the Inkscape SVG vector file: Ironic_mascot.svg

All images are licensed CC BY-SA.

Pixie Boots rockin': \m/ ʕ•͡ᴥ•ʔ \m/

Misc.

Outside the OpenStack Bare Metal Provisioning Program

Out-of-tree Ironic drivers

Drivers that can be used with Ironic but that aren't in the ironic repository, may be found in the ironic-staging-drivers repository.

Vendor-specific tools

Third-party vendors are encouraged to share their tools/scripts which might help people using their hardware with ironic. These tools are not maintained by the ironic core team and are not under the governance of the OpenStack Technical Committee. Vendors themselves should be contacted for features requests/bug fixes.

Developer doc https://wiki.openstack.org/wiki/Ironic/ThirdPartyVendorToolsDeveloperDoc
List of third party vendor tools https://wiki.openstack.org/wiki/Ironic/ThirdPartyVendorToolsList