Skip to content

Latest commit

 

History

History
88 lines (59 loc) · 3.51 KB

README.md

File metadata and controls

88 lines (59 loc) · 3.51 KB

OpenStack client tooling in Docker

Use a docker image for openstack client tooling!

Rather than futzing with all of the python dependencies to get the openstack cli tools working, use this Docker image as way to get started quickly. There are other openstack-cli images available -- this one uses a smaller footprint by building off of the Alpine image.

This particular version of this container will also install the neutron networking tools.

The original version of this project can be found here: https://github.com/jmcvea/docker-openstack-client

Here be dragons! That project hasn't been updated in two years!

If you're using this image you probably are running the older openstack since the newer modules will work in python. This image is built with python-neutronclient 6.7.0 and python-openstackclient 3.12.0.

Quick Start

docker pull ghostoftiber/openstack-client

# $(PWD) is mounted to allow for actions requiring host filesystem access.  
# See 'Tips' section below
docker run -ti --rm -v $(PWD):/data ghostoftiber/openstack-client

# source the rc config file
$ source /data/openrc.sh

Manual Build

Clone this repository, then:

# Build a local docker image
docker build -t openstack-client .

# Start a container from the image and launch into a shell in the container.
# Uses a dotenv file to manage the OpenStack rc env vars.
docker run -it --env-file ~/.osc_rc.env openstack-client

# If you like to mount your config files instead of passing via a dotenv file: (`openrc.sh` must be in the current directory)
docker run -it -v $(PWD):/data openstack-client
$ source /data/openrc.sh

Tips

Accessing a host directory

The /data directory is exposed as a VOLUME that can be mounted. This is convenient for openstack commands that might require reading/writing host filesystems. It is important to remember that commands such as openstack image save should ensure that the location where the image is saved is in the /data folder when using the --rm command line option. Example:

docker run -it --rm -v $(PWD):/data --env-file ${RC_ENV_FILE:-~/.osc_rc.env} ghostoftiber/openstack-client openstack image save --file /data/test_image.img ${IMAGE_GUID}

Run one-off commands

Run individual commands easily by passing them as the command to run and overriding the default /bin/sh command. For one-off commands, it's a good practice to remove the container with the --rm argument so that you don't collect a bunch of orphaned containers. You will also want to ensure that the rc environment is configured as part of starting the container -- easiest via a .env file containing the openstack rc env vars.

docker run -ti --rm -v $(PWD):/data --env-file ${RC_ENV_FILE:-~/.osc_rc.env} ghostoftiber/openstack-client cinder list`

Simplify your typing with aliases

# Get into a shell to run openstack commands
alias oscsh='docker run -ti --rm -v $(PWD):/data --env-file ${RC_ENV_FILE:-~/.osc_rc.env} ghostoftiber/openstack-client'
# Make it look like you're running openstack locally
alias openstack='oscsh openstack'

Errors

'Port' object has no attribute 'keys' is a result of using a newer openstack client with an older openstack deployment.

Contributing

  1. Fork ( http://github.com/tibers/docker-openstack-client/fork )
  2. Create a feature branch (git checkout -b new-feature)
  3. Commit changes (git commit -am 'Adding a great new feature')
  4. Push to the branch (git push origin new-feature)
  5. Create a new Pull Request

Copyright

Licensed under MIT