Ansible Modules Collection for using OpenStack
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Sagi Shnaidman 07374a1f0d Add mandatory requires_ansible version to metadata 1 year ago
changelogs Add missing info to changelog 1 year ago
ci Remove semver check from release job 1 year ago
contrib Update author lines 2 years ago
docs Guidelines: Fix links and formatting 2 years ago
meta Add mandatory requires_ansible version to metadata 1 year ago
plugins Merge "Wait for pool to be active and online" 1 year ago
scripts/inventory Moved openstack inventory script from community.general 3 years ago
tests Prepare for Ansible 2.11 tests 2 years ago
tools Temporarly disable check-import 2 years ago
.gitignore Add galaxy.yml to support install from git 2 years ago
.gitreview Added .gitreview 3 years ago
.zuul.yaml Add mandatory requires_ansible version to metadata 1 year ago
CHANGELOG.rst Add missing info to changelog 1 year ago
CONTRIBUTING.rst Add contributing file 3 years ago
COPYING Fix license metadata 3 years ago Update IRC server in README 1 year ago
bindep.txt Add bindep.txt for ansible-builder 2 years ago
galaxy.yml Bump to devel 1.5.1-dev version 1 year ago Add galaxy.yml to support install from git 2 years ago
requirements.txt Add execution environment metadata 2 years ago
setup.cfg setup.cfg: Replace dashes with underscores 2 years ago Add for install with pip 3 years ago
test-requirements-2.9.txt Fix linters for new ansible release 2 years ago
test-requirements-2.11.txt Fix Ansible devel jobs 2 years ago
test-requirements.txt Prepare for Ansible 2.11 tests 2 years ago
tox.ini Add automatic release job triggered by tag 1 year ago

OpenDev Zuul Builds - Ansible Collection OpenStack

Ansible Collection:

This repo hosts the Ansible Collection.

The collection includes the Openstack modules and plugins supported by Openstack community to help the management of Openstack infrastructure.

Installation and Usage

Installing dependencies

For using the Openstack Cloud collection firstly you need to install ansible and openstacksdk Python modules on your Ansible controller. For example with pip:

pip install ansible openstacksdk

OpenStackSDK has to be available to Ansible and to the Python interpreter on the host, where Ansible executes the module (target host). Please note, that under some circumstances Ansible might invoke a non-standard Python interpreter on the target host. Using Python version 3 is highly recommended for OpenstackSDK and strongly required from OpenstackSDK version 0.39.0.


OpenstackSDK is better to be the last stable version. It should NOT be installed on Openstack nodes, but rather on operators host (aka "Ansible controller"). OpenstackSDK from last version supports operations on all Openstack cloud versions. Therefore OpenstackSDK module version doesn't have to match Openstack cloud version usually.

Installing the Collection from Ansible Galaxy

Before using the Openstack Cloud collection, you need to install the collection with the ansible-galaxy CLI:

ansible-galaxy collection install

You can also include it in a requirements.yml file and install it through ansible-galaxy collection install -r requirements.yml using the format:

- name:


To use a module from the Openstack Cloud collection, please reference the full namespace, collection name, and module name that you want to use:

- name: Using Openstack Cloud collection
  hosts: localhost
        name: vm
        state: present
        cloud: openstack
        region_name: ams01
        image: Ubuntu Server 14.04
        flavor_ram: 4096
        boot_from_volume: True
        volume_size: 75

Or you can add the full namespace and collection name in the collections element:

- name: Using Openstack Cloud collection
  hosts: localhost
    - server_volume:
        state: present
        cloud: openstack
        server: Mysql-server
        volume: mysql-data
        device: /dev/vdb


For information on contributing, please see CONTRIBUTING

There are many ways in which you can participate in the project, for example:

We work with OpenDev Gerrit, pull requests submitted through GitHub will be ignored.

Testing and Development

If you want to develop new content for this collection or improve what is already here, the easiest way to work on the collection is to clone it into one of the configured COLLECTIONS_PATHS, and work on it there.

Testing with ansible-test

We use ansible-test for sanity:

tox -e linters

More Information



We have a dedicated Interest Group for Openstack Ansible modules. You can find other people interested in this in #openstack-ansible-sig on OFTC IRC.


GNU General Public License v3.0 or later

See LICENCE to see the full text.