2011-02-08 12:54:34 +00:00
|
|
|
Python bindings to the OpenStack Nova API
|
2011-01-25 20:01:22 +00:00
|
|
|
==================================================
|
|
|
|
|
2011-02-08 12:54:34 +00:00
|
|
|
This is a client for the OpenStack Nova API. There's a Python API (the
|
2011-02-26 09:04:40 +00:00
|
|
|
``novaclient`` module), and a command-line script (``nova``). Each
|
2011-02-08 12:54:34 +00:00
|
|
|
implements 100% of the OpenStack Nova API.
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2012-12-31 21:29:53 +00:00
|
|
|
See the `OpenStack CLI guide`_ for information on how to use the ``nova``
|
|
|
|
command-line tool. You may also want to look at the
|
|
|
|
`OpenStack API documentation`_.
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2012-12-31 21:29:53 +00:00
|
|
|
.. _OpenStack CLI Guide: http://docs.openstack.org/cli/quick-start/content/
|
|
|
|
.. _OpenStack API documentation: http://docs.openstack.org/api/
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2011-12-02 03:13:07 +00:00
|
|
|
The project is hosted on `Launchpad`_, where bugs can be filed. The code is
|
|
|
|
hosted on `Github`_. Patches must be submitted using `Gerrit`_, *not* Github
|
|
|
|
pull requests.
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2011-12-02 03:13:07 +00:00
|
|
|
.. _Github: https://github.com/openstack/python-novaclient
|
|
|
|
.. _Launchpad: https://launchpad.net/python-novaclient
|
|
|
|
.. _Gerrit: http://wiki.openstack.org/GerritWorkflow
|
2011-02-08 12:54:34 +00:00
|
|
|
|
2012-12-31 21:29:53 +00:00
|
|
|
python-novaclient is licensed under the Apache License like the rest of
|
|
|
|
OpenStack.
|
2011-02-08 12:54:34 +00:00
|
|
|
|
2011-01-25 20:01:22 +00:00
|
|
|
|
|
|
|
.. contents:: Contents:
|
|
|
|
:local:
|
|
|
|
|
|
|
|
Command-line API
|
|
|
|
----------------
|
|
|
|
|
2011-02-24 17:54:10 +00:00
|
|
|
Installing this package gets you a shell command, ``nova``, that you
|
2012-12-31 21:29:53 +00:00
|
|
|
can use to interact with any OpenStack cloud.
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2012-03-14 03:30:52 +00:00
|
|
|
You'll need to provide your OpenStack username and password. You can do this
|
2012-08-22 18:01:17 +00:00
|
|
|
with the ``--os-username``, ``--os-password`` and ``--os-tenant-name``
|
2012-03-14 03:30:52 +00:00
|
|
|
params, but it's easier to just set them as environment variables::
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2012-03-14 03:30:52 +00:00
|
|
|
export OS_USERNAME=openstack
|
|
|
|
export OS_PASSWORD=yadayada
|
|
|
|
export OS_TENANT_NAME=myproject
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2012-08-22 18:01:17 +00:00
|
|
|
You will also need to define the authentication url with ``--os-auth-url``
|
2012-03-14 03:30:52 +00:00
|
|
|
and the version of the API with ``--version``. Or set them as an environment
|
2011-08-07 19:00:23 +00:00
|
|
|
variables as well::
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2012-03-14 03:30:52 +00:00
|
|
|
export OS_AUTH_URL=http://example.com:8774/v1.1/
|
2012-04-12 19:16:31 +00:00
|
|
|
export OS_COMPUTE_API_VERSION=1.1
|
2011-08-13 06:47:25 +00:00
|
|
|
|
|
|
|
If you are using Keystone, you need to set the NOVA_URL to the keystone
|
|
|
|
endpoint::
|
|
|
|
|
2012-03-14 03:30:52 +00:00
|
|
|
export OS_AUTH_URL=http://example.com:5000/v2.0/
|
2011-08-08 20:20:44 +00:00
|
|
|
|
2011-09-07 20:30:20 +00:00
|
|
|
Since Keystone can return multiple regions in the Service Catalog, you
|
2012-08-22 18:01:17 +00:00
|
|
|
can specify the one you want with ``--os-region-name`` (or
|
2012-03-14 03:30:52 +00:00
|
|
|
``export OS_REGION_NAME``). It defaults to the first in the list returned.
|
2011-09-02 19:07:18 +00:00
|
|
|
|
2011-08-08 20:20:44 +00:00
|
|
|
You'll find complete documentation on the shell by running
|
2011-02-24 17:54:10 +00:00
|
|
|
``nova help``::
|
2011-08-07 19:00:23 +00:00
|
|
|
|
2012-08-22 18:01:17 +00:00
|
|
|
usage: nova [--debug] [--no-cache] [--timings]
|
|
|
|
[--os-username <auth-user-name>] [--os-password <auth-password>]
|
|
|
|
[--os-tenant-name <auth-tenant-name>] [--os-auth-url <auth-url>]
|
|
|
|
[--os-region-name <region-name>] [--os-auth-system <auth-system>]
|
|
|
|
[--service-type <service-type>] [--service-name <service-name>]
|
|
|
|
[--volume-service-name <volume-service-type>]
|
|
|
|
[--endpoint-type <endpoint-type>]
|
|
|
|
[--os-compute-api-version <compute-api-ver>] [--insecure]
|
|
|
|
[--bypass-url <bypass-url>]
|
2012-03-14 03:30:52 +00:00
|
|
|
<subcommand> ...
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2011-02-08 12:54:34 +00:00
|
|
|
Command-line interface to the OpenStack Nova API.
|
2011-01-25 20:01:22 +00:00
|
|
|
|
|
|
|
Positional arguments:
|
|
|
|
<subcommand>
|
2012-03-19 22:36:55 +00:00
|
|
|
absolute-limits Print a list of absolute limits for a user
|
|
|
|
actions Retrieve server actions.
|
|
|
|
add-fixed-ip Add new IP address to network.
|
2011-10-11 04:07:08 +00:00
|
|
|
add-floating-ip Add a floating IP address to a server.
|
2012-03-19 22:36:55 +00:00
|
|
|
aggregate-add-host Add the host to the specified aggregate.
|
|
|
|
aggregate-create Create a new aggregate with the specified details.
|
|
|
|
aggregate-delete Delete the aggregate by its id.
|
|
|
|
aggregate-details Show details of the specified aggregate.
|
|
|
|
aggregate-list Print a list of all aggregates.
|
2012-01-13 13:36:01 +00:00
|
|
|
aggregate-remove-host
|
2012-06-12 00:49:22 +00:00
|
|
|
Remove the specified host from the specified aggregate.
|
2012-01-13 13:36:01 +00:00
|
|
|
aggregate-set-metadata
|
2012-03-19 22:36:55 +00:00
|
|
|
Update the metadata associated with the aggregate.
|
2012-01-13 13:36:01 +00:00
|
|
|
aggregate-update Update the aggregate's name and optionally
|
2012-03-19 22:36:55 +00:00
|
|
|
availability zone.
|
2011-01-25 20:01:22 +00:00
|
|
|
boot Boot a new server.
|
2012-03-19 22:36:55 +00:00
|
|
|
console-log Get console log output of a server.
|
|
|
|
credentials Show user credentials returned from auth
|
2011-01-25 20:01:22 +00:00
|
|
|
delete Immediately shut down and delete a server.
|
2012-03-19 22:36:55 +00:00
|
|
|
describe-resource Show details about a resource
|
|
|
|
diagnostics Retrieve server diagnostics.
|
|
|
|
dns-create Create a DNS entry for domain, name and ip.
|
|
|
|
dns-create-private-domain
|
|
|
|
Create the specified DNS domain.
|
|
|
|
dns-create-public-domain
|
|
|
|
Create the specified DNS domain.
|
|
|
|
dns-delete Delete the specified DNS entry.
|
|
|
|
dns-delete-domain Delete the specified DNS domain.
|
|
|
|
dns-domains Print a list of available dns domains.
|
|
|
|
dns-list List current DNS entries for domain and ip or domain
|
|
|
|
and name.
|
|
|
|
endpoints Discover endpoints that get returned from the
|
|
|
|
authenticate services
|
2013-01-07 16:46:59 +00:00
|
|
|
evacuate Evacuate a server from failed host
|
2013-05-14 13:47:10 +00:00
|
|
|
flavor-create Create a new flavor.
|
|
|
|
flavor-delete Delete a specific flavor.
|
2011-01-25 20:01:22 +00:00
|
|
|
flavor-list Print a list of available 'flavors' (sizes of
|
|
|
|
servers).
|
2013-05-14 13:47:10 +00:00
|
|
|
flavor-show Show details about the given flavor.
|
|
|
|
flavor-key Set or unset extra_spec for a flavor.
|
|
|
|
flavor-access-list Print access information about the given flavor.
|
|
|
|
flavor-access-add Add flavor access for the given tenant.
|
|
|
|
flavor-access-remove
|
|
|
|
Remove flavor access for the given tenant.
|
2012-03-19 22:36:55 +00:00
|
|
|
floating-ip-create Allocate a floating IP for the current tenant.
|
|
|
|
floating-ip-delete De-allocate a floating IP.
|
|
|
|
floating-ip-list List floating ips for this tenant.
|
2012-01-09 22:49:12 +00:00
|
|
|
floating-ip-pool-list
|
|
|
|
List all floating ip pools.
|
2012-03-19 22:36:55 +00:00
|
|
|
get-vnc-console Get a vnc console to a server.
|
2013-01-02 18:37:25 +00:00
|
|
|
get-spice-console Get a spice console to a server.
|
2012-03-19 22:36:55 +00:00
|
|
|
host-action Perform a power action on a host.
|
|
|
|
host-update Update host settings.
|
2011-01-25 20:01:22 +00:00
|
|
|
image-create Create a new image by taking a snapshot of a running
|
|
|
|
server.
|
|
|
|
image-delete Delete an image.
|
|
|
|
image-list Print a list of available images to boot from.
|
2012-03-19 22:36:55 +00:00
|
|
|
image-meta Set or Delete metadata on an image.
|
|
|
|
image-show Show details about the given image.
|
2011-10-05 12:25:31 +00:00
|
|
|
keypair-add Create a new key pair for use with instances
|
2013-03-22 12:29:55 +00:00
|
|
|
keypair-delete Delete keypair by its name
|
2012-03-19 22:36:55 +00:00
|
|
|
keypair-list Print a list of keypairs for a user
|
2011-01-25 20:01:22 +00:00
|
|
|
list List active servers.
|
2012-03-19 22:36:55 +00:00
|
|
|
live-migration Migrates a running instance to a new machine.
|
|
|
|
lock Lock a server.
|
|
|
|
meta Set or Delete metadata on a server.
|
|
|
|
migrate Migrate a server.
|
|
|
|
pause Pause a server.
|
|
|
|
rate-limits Print a list of rate limits for a user
|
2011-01-25 20:01:22 +00:00
|
|
|
reboot Reboot a server.
|
|
|
|
rebuild Shutdown, re-image, and re-boot a server.
|
2011-07-08 17:57:27 +00:00
|
|
|
remove-fixed-ip Remove an IP address from a server.
|
2011-10-11 04:07:08 +00:00
|
|
|
remove-floating-ip Remove a floating IP address from a server.
|
2011-01-25 20:01:22 +00:00
|
|
|
rename Rename a server.
|
|
|
|
rescue Rescue a server.
|
|
|
|
resize Resize a server.
|
|
|
|
resize-confirm Confirm a previous resize.
|
|
|
|
resize-revert Revert a previous resize (and return to the previous
|
|
|
|
VM).
|
2012-03-19 22:36:55 +00:00
|
|
|
resume Resume a server.
|
2011-01-25 20:01:22 +00:00
|
|
|
root-password Change the root password for a server.
|
2011-10-11 22:10:23 +00:00
|
|
|
secgroup-add-group-rule
|
2011-10-11 22:30:48 +00:00
|
|
|
Add a source group rule to a security group.
|
2011-10-11 07:48:55 +00:00
|
|
|
secgroup-add-rule Add a rule to a security group.
|
2012-03-19 22:36:55 +00:00
|
|
|
secgroup-create Create a security group.
|
2013-05-22 08:28:34 +00:00
|
|
|
secgroup-update Update a security group.
|
2011-10-11 07:48:55 +00:00
|
|
|
secgroup-delete Delete a security group.
|
2011-10-11 22:10:23 +00:00
|
|
|
secgroup-delete-group-rule
|
|
|
|
Delete a source group rule from a security group.
|
2011-10-11 07:48:55 +00:00
|
|
|
secgroup-delete-rule
|
|
|
|
Delete a rule from a security group.
|
|
|
|
secgroup-list List security groups for the curent tenant.
|
2012-03-19 22:36:55 +00:00
|
|
|
secgroup-list-rules
|
|
|
|
List rules for a security group.
|
2011-01-25 20:01:22 +00:00
|
|
|
show Show details about the given server.
|
2012-03-19 22:36:55 +00:00
|
|
|
ssh SSH into a server.
|
2012-06-01 01:39:20 +00:00
|
|
|
start Start a server.
|
|
|
|
stop Stop a server.
|
2011-10-19 17:54:27 +00:00
|
|
|
suspend Suspend a server.
|
2012-03-14 06:18:41 +00:00
|
|
|
unlock Unlock a server.
|
2011-10-19 17:54:27 +00:00
|
|
|
unpause Unpause a server.
|
2011-01-25 20:01:22 +00:00
|
|
|
unrescue Unrescue a server.
|
2012-01-22 23:56:39 +00:00
|
|
|
usage-list List usage data for all tenants
|
2011-09-29 15:09:50 +00:00
|
|
|
volume-attach Attach a volume to a server.
|
|
|
|
volume-create Add a new volume.
|
|
|
|
volume-delete Remove a volume.
|
|
|
|
volume-detach Detach a volume from a server.
|
|
|
|
volume-list List all the volumes.
|
|
|
|
volume-show Show details about a volume.
|
2011-11-09 18:36:16 +00:00
|
|
|
volume-snapshot-create
|
|
|
|
Add a new snapshot.
|
|
|
|
volume-snapshot-delete
|
|
|
|
Remove a snapshot.
|
|
|
|
volume-snapshot-list
|
|
|
|
List all the snapshots.
|
|
|
|
volume-snapshot-show
|
|
|
|
Show details about a snapshot.
|
2012-03-19 22:36:55 +00:00
|
|
|
volume-type-create Create a new volume type.
|
|
|
|
volume-type-delete Delete a specific flavor
|
|
|
|
volume-type-list Print a list of available 'volume types'.
|
2012-01-20 23:08:53 +00:00
|
|
|
x509-create-cert Create x509 cert for a user in tenant
|
|
|
|
x509-get-root-cert Fetches the x509 root cert.
|
2012-03-19 22:36:55 +00:00
|
|
|
bash-completion Prints all of the commands and options to stdout so
|
|
|
|
that the
|
|
|
|
help Display help about this program or one of its
|
|
|
|
subcommands.
|
2011-01-25 20:01:22 +00:00
|
|
|
|
|
|
|
Optional arguments:
|
2012-03-14 03:30:52 +00:00
|
|
|
--debug Print debugging output
|
2012-08-22 18:01:17 +00:00
|
|
|
--no-cache Don't use the auth token cache.
|
|
|
|
--timings Print call timing info
|
|
|
|
--os-username <auth-user-name>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to env[OS_USERNAME].
|
2012-08-22 18:01:17 +00:00
|
|
|
--os-password <auth-password>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to env[OS_PASSWORD].
|
2012-08-22 18:01:17 +00:00
|
|
|
--os-tenant-name <auth-tenant-name>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to env[OS_TENANT_NAME].
|
2012-08-22 18:01:17 +00:00
|
|
|
--os-auth-url <auth-url>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to env[OS_AUTH_URL].
|
2012-08-22 18:01:17 +00:00
|
|
|
--os-region-name <region-name>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to env[OS_REGION_NAME].
|
2012-08-22 18:01:17 +00:00
|
|
|
--os-auth-system <auth-system>
|
|
|
|
Defaults to env[OS_AUTH_SYSTEM].
|
|
|
|
--service-type <service-type>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to compute for most actions
|
2012-08-22 18:01:17 +00:00
|
|
|
--service-name <service-name>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to env[NOVA_SERVICE_NAME]
|
2012-08-22 18:01:17 +00:00
|
|
|
--volume-service-name <volume-service-type>
|
|
|
|
Defaults to env[NOVA_VOLUME_SERVICE_NAME]
|
|
|
|
--endpoint-type <endpoint-type>
|
2012-03-14 03:30:52 +00:00
|
|
|
Defaults to env[NOVA_ENDPOINT_TYPE] or publicURL.
|
2012-08-22 18:01:17 +00:00
|
|
|
--os-compute-api-version <compute-api-ver>
|
|
|
|
Accepts 1.1, defaults to env[OS_COMPUTE_API_VERSION]. --username USERNAME Deprecated
|
|
|
|
--insecure Explicitly allow novaclient to perform "insecure" SSL
|
|
|
|
(https) requests. The server's certificate will not be
|
|
|
|
verified against any certificate authorities. This
|
|
|
|
option should be used with caution.
|
|
|
|
--bypass-url <bypass-url>
|
|
|
|
Use this API endpoint instead of the Service Catalog
|
2011-01-25 20:01:22 +00:00
|
|
|
|
2011-02-24 17:54:10 +00:00
|
|
|
See "nova help COMMAND" for help on a specific command.
|
2011-08-08 20:20:44 +00:00
|
|
|
|
2011-01-25 20:01:22 +00:00
|
|
|
Python API
|
|
|
|
----------
|
|
|
|
|
2012-12-31 21:29:53 +00:00
|
|
|
There's also a complete Python API, but it has not yet been documented.
|
2011-01-25 20:01:22 +00:00
|
|
|
|
|
|
|
|
2011-08-10 23:16:38 +00:00
|
|
|
Quick-start using keystone::
|
|
|
|
|
|
|
|
# use v2.0 auth with http://example.com:5000/v2.0/")
|
|
|
|
>>> from novaclient.v1_1 import client
|
2012-04-18 06:31:28 +00:00
|
|
|
>>> nt = client.Client(USER, PASS, TENANT, AUTH_URL, service_type="compute")
|
2011-08-10 23:16:38 +00:00
|
|
|
>>> nt.flavors.list()
|
|
|
|
[...]
|
|
|
|
>>> nt.servers.list()
|
|
|
|
[...]
|
|
|
|
>>> nt.keypairs.list()
|
|
|
|
[...]
|