A Python agent for provisioning and deprovisioning Bare Metal servers.
Go to file
Mathieu Mitchell a0ca6ce157 Enforce upper-constraints when building ramdisks
Currently, building ramdisks installs ironic-python-agent without any
upper-constraints. This causes the package to be installed with newer,
untested dependencies.

This commits introduces a tool to generate a local upper-constraints
file based on predefined strategies (below). Additionally, the fallback
to the openstack/requirements uses the URL defined in tox.ini instead of
redefining it. This prevents having to keep track of two separate
variables when releasing.

upper-constraints lookup strategies (in order):

  * UPPER_CONSTRAINTS_FILE points to a local file
  * UPPER_CONSTRAINTS_FILE points to a URL
  * /opt/stack/new/requirements/upper-constraints.txt
  * upper-constraints.txt from openstack/requirements git repository

Partial-bug: #1616554
Change-Id: Ib5c0c57cafdb6ffd7456e61f3b1bb5fa57520e5a
2016-08-26 09:06:24 -04:00
doc/source Minor updates to metrics documentation 2016-08-11 23:09:12 -04:00
etc/ironic_python_agent Added some infrastructure tools 2014-04-03 21:09:11 +04:00
imagebuild Enforce upper-constraints when building ramdisks 2016-08-26 09:06:24 -04:00
ironic_python_agent Build socket list right before select call 2016-08-17 16:35:07 +02:00
releasenotes Build socket list right before select call 2016-08-17 16:35:07 +02:00
tools Added some infrastructure tools 2014-04-03 21:09:11 +04:00
.gitignore Enforce upper-constraints when building ramdisks 2016-08-26 09:06:24 -04:00
.gitreview add(gerrit support): Required to move to openstack 2014-03-07 13:30:45 -08:00
.testr.conf Split functional and py27 tests 2015-08-28 14:16:34 -07:00
.travis.yml Preparing for OpenStack testing environment 2014-03-11 12:50:12 -07:00
Dockerfile Enforce upper-constraints when building ramdisks 2016-08-26 09:06:24 -04:00
LICENSE add license file 2013-09-17 13:41:59 -07:00
README.rst Add DIB ironic-agent element to readme for IPA 2016-02-24 15:32:10 -06:00
plugin-requirements.txt Add "logs" and "extra-hardware" inspection collectors 2015-10-01 18:25:30 +02:00
proxy.sh Add support for proxy servers during image build 2016-02-04 14:27:49 -08:00
requirements.txt Updated from global requirements 2016-08-04 02:35:43 +00:00
setup.cfg Add a log extension 2016-06-28 17:02:11 +01:00
setup.py Updated from global requirements 2015-09-17 16:39:02 +00:00
test-requirements.txt Remove discover from test-requirements 2016-07-21 11:28:36 -04:00
tox.ini Use upper-constraints for all tox targets 2016-08-19 08:50:20 -04:00

README.rst

ironic-python-agent

An agent for controlling and deploying Ironic controlled baremetal nodes.

The ironic-python-agent works with the agent driver in Ironic to provision the node. Starting with ironic-python-agent running on a ramdisk on the unprovisioned node, Ironic makes API calls to ironic-python-agent to provision the machine. This allows for greater control and flexibility of the entire deployment process.

The ironic-python-agent may also be used with the original Ironic pxe drivers as of the Kilo OpenStack release.

Building the IPA deployment ramdisk

For more information see the Image Builder section of the Ironic Python Agent developer guide.

Using IPA with devstack

This is covered in the Deploying Ironic with DevStack section of the Ironic dev-quickstart guide.

Project Resources

Project status, bugs, and blueprints are tracked on Launchpad:

http://launchpad.net/ironic-python-agent

Developer documentation can be found here:

http://docs.openstack.org/developer/ironic-python-agent

Additional resources are linked from the project wiki page:

https://wiki.openstack.org/wiki/Ironic-python-agent

IRC channel:

#openstack-ironic

To contribute, start here: Openstack: How to contribute.