OpenStackClient has a consistent and predictable format for all of its commands.
Global Options
Global options are global in the sense that they apply to every command
invocation regardless of action to be performed. They include authentication
credentials and API version selection. Most global options have a corresponding
environment variable that may also be used to set the value. If both are
present, the command-line option takes priority. The environment variable
names are derived from the option name by dropping the leading dashes (--),
converting each embedded dash (-) to an underscore (_), and converting
to upper case.
For example, the default value of --os-username can be set by defining
the environment variable OS_USERNAME.
Command Object(s) and Action
Commands consist of an object described by one or more words followed by
an action. Commands that require two objects have the primary object ahead
of the action and the secondary object after the action. Any positional
arguments identifying the objects shall appear in the same order as the
objects. In badly formed English it is expressed as “(Take) object1
(and perform) action (using) object2 (to it).”
<object-1> <action> <object-2>
Examples:
$ group add user <group> <user>
$ volume type list # 'volume type' is a two-word single object
Objects
The objects consist of one or more words to compose a unique name.
Occasionally when multiple APIs have a common name with common
overlapping purposes there will be options to select which object to use, or
the API resources will be merged, as in the quota object that has options
referring to both Compute and Volume quotas.
- access token: (Identity) long-lived OAuth-based token
- address scope: (Network) a scope of IPv4 or IPv6 addresses
- aggregate: (Compute) a grouping of compute hosts
- availability zone: (Compute, Network, Volume) a logical partition of hosts or block storage or network services
- backup: (Volume) a volume copy
- catalog: (Identity) service catalog
- command: (Internal) installed commands in the OSC process
- compute agent: (Compute) a cloud Compute agent available to a hypervisor
- compute service: (Compute) a cloud Compute process running on a host
- configuration: (Internal) OpenStack client configuration
- console log: (Compute) server console text dump
- console url: (Compute) server remote console URL
- consumer: (Identity) OAuth-based delegatee
- container: (Object Storage) a grouping of objects
- credential: (Identity) specific to identity providers
- domain: (Identity) a grouping of projects
- ec2 credentials: (Identity) AWS EC2-compatible credentials
- endpoint: (Identity) the base URL used to contact a specific service
- extension: (Compute, Identity, Network, Volume) OpenStack server API extensions
- federation protocol: (Identity) the underlying protocol used while federating identities
- flavor: (Compute) predefined server configurations: ram, root disk and so on
- fixed ip: (Compute, Network) - an internal IP address assigned to a server
- floating ip: (Compute, Network) - a public IP address that can be mapped to a server
- floating ip pool: (Compute, Network) - a pool of public IP addresses
- group: (Identity) a grouping of users
- host: (Compute) - the physical computer running compute services
- hypervisor: (Compute) the virtual machine manager
- hypervisor stats: (Compute) hypervisor statistics over all compute nodes
- identity provider: (Identity) a source of users and authentication
- image: (Image) a disk image
- ip availability: (Network) - details of IP usage of a network
- ip fixed: (Compute, Network) - an internal IP address assigned to a server
- ip floating: (Compute, Network) - a public IP address that can be mapped to a server
- ip floating pool: (Compute, Network) - a pool of public IP addresses
- keypair: (Compute) an SSH public key
- limits: (Compute, Volume) resource usage limits
- mapping: (Identity) a definition to translate identity provider attributes to Identity concepts
- module: (Internal) - installed Python modules in the OSC process
- network: (Compute, Network) - a virtual network for connecting servers and other resources
- network agent: (Network) - A network agent is an agent that handles various tasks used to implement virtual networks
- network rbac: (Network) - an RBAC policy for network resources
- network segment: (Network) - a segment of a virtual network
- object: (Object Storage) a single file in the Object Storage
- object store account: (Object Storage) owns a group of Object Storage resources
- policy: (Identity) determines authorization
- port: (Network) - a virtual port for connecting servers and other resources to a network
- project: (Identity) owns a group of resources
- quota: (Compute, Volume) resource usage restrictions
- region: (Identity) a subset of an OpenStack deployment
- request token: (Identity) temporary OAuth-based token
- role: (Identity) a policy object used to determine authorization
- role assignment: (Identity) a relationship between roles, users or groups, and domains or projects
- router: (Network) - a virtual router
- security group: (Compute, Network) - groups of network access rules
- security group rule: (Compute, Network) - the individual rules that define protocol/IP/port access
- server: (Compute) virtual machine instance
- server backup: (Compute) backup server disk image by using snapshot method
- server dump: (Compute) a dump file of a server created by features like kdump
- server group: (Compute) a grouping of servers
- server image: (Compute) saved server disk image
- service: (Identity) a cloud service
- service provider: (Identity) a resource that consumes assertions from an identity provider
- snapshot: (Volume) a point-in-time copy of a volume
- subnet: (Network) - a contiguous range of IP addresses assigned to a network
- subnet pool: (Network) - a pool of subnets
- token: (Identity) a bearer token managed by Identity service
- trust: (Identity) project-specific role delegation between users, with optional impersonation
- usage: (Compute) display host resources being consumed
- user: (Identity) individual cloud resources users
- user role: (Identity) roles assigned to a user
- volume: (Volume) block volumes
- volume qos: (Volume) quality-of-service (QoS) specification for volumes
- volume type: (Volume) deployment-specific types of volumes available
- volume service: (Volume) services to manage block storage operations
- volume transfer request: (Volume) volume owner transfer request
Command Entry Points
Commands are added to the client using setuptools entry points in setup.cfg.
There is a single common group openstack.cli for commands that are not versioned,
and a group for each combination of OpenStack API and version that is
supported. For example, to support Identity API v3 there is a group called
openstack.identity.v3 that contains the individual commands. The command
entry points have the form:
action_object = fully.qualified.module.vXX.object:ActionObject
For example, the list user command for the Identity API is identified in
setup.cfg with:
openstack.identity.v3 =
# ...
list_user = openstackclient.identity.v3.user:ListUser
# ...