8835198b8d
Closes-Bug: #1691871 Related-Bug: #1784826 Change-Id: Ifc6f1549d88a1b7d9f6e25c962c8a15dd8e180fb
306 lines
12 KiB
ReStructuredText
306 lines
12 KiB
ReStructuredText
========================
|
|
Key Compute API Concepts
|
|
========================
|
|
|
|
The OpenStack Compute API is defined as a RESTful HTTP service. The API
|
|
takes advantage of all aspects of the HTTP protocol (methods, URIs,
|
|
media types, response codes, etc.) and providers are free to use
|
|
existing features of the protocol such as caching, persistent
|
|
connections, and content compression among others.
|
|
|
|
Providers can return information identifying requests in HTTP response
|
|
headers, for example, to facilitate communication between the provider
|
|
and client applications.
|
|
|
|
OpenStack Compute is a compute service that provides server capacity in
|
|
the cloud. Compute Servers come in different flavors of memory, cores,
|
|
disk space, and CPU, and can be provisioned in minutes. Interactions
|
|
with Compute Servers can happen programmatically with the OpenStack
|
|
Compute API.
|
|
|
|
User Concepts
|
|
=============
|
|
|
|
To use the OpenStack Compute API effectively, you should understand
|
|
several key concepts:
|
|
|
|
- **Server**
|
|
|
|
A virtual machine (VM) instance, physical machine or a container in the
|
|
compute system. Flavor and image are requisite elements when creating a
|
|
server. A name for the server is also required.
|
|
|
|
For more details, such as server actions and server metadata,
|
|
please see: :doc:`server_concepts`
|
|
|
|
- **Flavor**
|
|
|
|
Virtual hardware configuration for the requested server. Each flavor has a
|
|
unique combination of disk space, memory capacity and priority for
|
|
CPU time.
|
|
|
|
- **Flavor Extra Specs**
|
|
|
|
Key and value pairs that can be used to describe the specification of
|
|
the server which more than just about CPU, disk and RAM. For example,
|
|
it can be used to indicate that the server created by this flavor has
|
|
PCI devices, etc.
|
|
|
|
For more details, please see: :doc:`extra_specs_and_properties`
|
|
|
|
- **Image**
|
|
|
|
A collection of files used to create or rebuild a server. Operators
|
|
provide a number of pre-built OS images by default. You may also
|
|
create custom images from cloud servers you have launched. These
|
|
custom images are useful for backup purposes or for producing "gold"
|
|
server images if you plan to deploy a particular server configuration
|
|
frequently.
|
|
|
|
- **Image Properties**
|
|
|
|
Key and value pairs that can help end users to determine the requirements
|
|
of the guest os in the image.
|
|
|
|
For more details, please see: :doc:`extra_specs_and_properties`
|
|
|
|
- **Key Pair**
|
|
|
|
An ssh or x509 keypair that can be injected into a server at it's boot time.
|
|
This allows you to connect to your server once it has been created without
|
|
having to use a password. If you don't specify a key pair, Nova will create
|
|
a root password for you, and return it in plain text in the server create
|
|
response.
|
|
|
|
- **Volume**
|
|
|
|
A block storage device that Nova can use as permanent storage. When a server
|
|
is created it has some disk storage available, but that is considered
|
|
ephemeral, as it is destroyed when the server is destroyed. A volume can be
|
|
attached to a server, then later detached and used by another server.
|
|
Volumes are created and managed by the Cinder service.
|
|
For additional info, see
|
|
:nova-doc:`Block device mapping <user/block-device-mapping.html>`
|
|
|
|
- **Quotas**
|
|
|
|
An upper limit on the amount of resources any individual tenant may consume.
|
|
Quotas can be used to limit the number of servers a tenant creates, or the
|
|
amount of disk space consumed, so that no one tenant can overwhelm the
|
|
system and prevent normal operation for others. Changing quotas is an
|
|
administrator-level action. For additional info,
|
|
see :nova-doc:`Quotas <user/quotas.html>`
|
|
|
|
- **Rate Limiting**
|
|
|
|
Please see :doc:`limits`
|
|
|
|
- **Availability zone**
|
|
|
|
A grouping of host machines that can be used to control where a new server
|
|
is created. There is some confusion about this, as the name "availability
|
|
zone" is used in other clouds, such as Amazon Web Services, to denote a
|
|
physical separation of server locations that can be used to distribute cloud
|
|
resources for fault tolerance in case one zone is unavailable for any
|
|
reason. Such a separation is possible in Nova if an administrator carefully
|
|
sets up availability zones for that, but it is not the default.
|
|
|
|
Networking Concepts
|
|
-------------------
|
|
|
|
In this section we focus on this related to networking.
|
|
|
|
- **Port**
|
|
|
|
TODO
|
|
|
|
- **Floating IPs, Pools and DNS**
|
|
|
|
TODO
|
|
|
|
- **Security Groups**
|
|
|
|
TODO
|
|
|
|
- **Extended Networks**
|
|
|
|
TODO
|
|
|
|
|
|
Administrator Concepts
|
|
======================
|
|
|
|
Some APIs are largely focused on administration of Nova, and generally focus
|
|
on compute hosts rather than servers.
|
|
|
|
- **Services**
|
|
|
|
Services are provided by Nova components. Normally, the Nova component runs
|
|
as a process on the controller/compute node to provide the service. These
|
|
services may be end-user facing, such as the OpenStack Compute REST API
|
|
service, but most just work with other Nova services. The status of each
|
|
service is monitored by Nova, and if it is not responding normally, Nova
|
|
will update its status so that requests are not sent to that service
|
|
anymore. The service can also be controlled by an Administrator in order to
|
|
run maintenance or upgrades, or in response to changing workloads.
|
|
|
|
- **nova-osapi_compute**
|
|
|
|
This service provides the OpenStack Compute REST API to end users and
|
|
application clients.
|
|
|
|
- **nova-metadata**
|
|
|
|
This service provides the OpenStack Metadata API to servers. The metadata
|
|
is used to configure the running servers.
|
|
|
|
- **nova-scheduler**
|
|
|
|
This service provides compute request scheduling by tracking available
|
|
resources, and finding the host that can best fulfill the request.
|
|
|
|
- **nova-conductor**
|
|
|
|
This service provides database access for Nova and the other OpenStack
|
|
services, and handles internal version compatibility when different
|
|
services are running different versions of code. The conductor service
|
|
also handles long-running requests.
|
|
|
|
- **nova-compute**
|
|
|
|
This service runs on every compute node, and communicates with a
|
|
hypervisor for managing compute resources on that node.
|
|
|
|
- **nova-network (deprecated)**
|
|
|
|
This service handles networking of virtual servers. It is no longer under
|
|
active development, and is being replaced by Neutron.
|
|
|
|
- **nova-consoleauth (deprecated)**
|
|
|
|
This service provides authorization for compute instances consoles.
|
|
|
|
- **Services Actions**
|
|
|
|
.. note::
|
|
The services actions described in this section apply only to
|
|
**nova-compute** services.
|
|
|
|
- **enable, disable, disable-log-reason**
|
|
|
|
The service can be disabled to indicate the service is not available anymore.
|
|
This is used by administrator to stop service for maintenance.
|
|
For example, when Administrator wants to maintain a specific compute node,
|
|
Administrator can disable nova-compute service on that compute node. Then
|
|
nova won't dispatch any new compute request to that compute node anymore.
|
|
Administrator also can add note for disable reason.
|
|
|
|
- **forced-down**
|
|
|
|
.. note::
|
|
This action is enabled in microversion 2.11.
|
|
|
|
This action allows you set the state of service down immediately. Nova
|
|
only provides a very basic health monitor of service status, there isn't
|
|
any guarantee about health status of other parts of infrastructure, like
|
|
the health status of data network, storage network and other
|
|
components.
|
|
|
|
If you have a more extensive health monitoring system external to Nova,
|
|
and know that the service in question is dead (and disconnected from the
|
|
network), this can be used to tell the rest of Nova it can trust that this
|
|
service is never coming back, and allow actions such as evacuate.
|
|
|
|
.. warning::
|
|
|
|
This must *only* be used if you have fully fenced the service in
|
|
question, and that it can never send updates to the rest of the
|
|
system. This can be done by powering off the node or completely
|
|
isolating its networking. If you force-down a service that is not
|
|
fenced you can corrupt the VMs that were running on that host.
|
|
|
|
- **Hosts**
|
|
|
|
Hosts are the *physical machines* that provide the resources for the virtual
|
|
servers created in Nova. They run a ``hypervisor`` (see definition below)
|
|
that handles the actual creation and management of the virtual servers.
|
|
Hosts also run the ``Nova compute service``, which receives requests from
|
|
Nova to interact with the virtual servers on that machine. When compute
|
|
service receives a request, it calls the appropriate methods of the driver
|
|
for that hypervisor in order to carry out the request. The driver acts as
|
|
the translator from generic Nova requests to hypervisor-specific calls.
|
|
Hosts report their current state back to Nova, where it is tracked by the
|
|
scheduler service, so that the scheduler can place requests for new virtual
|
|
servers on the hosts that can best fit them.
|
|
|
|
- **Host Actions**
|
|
|
|
.. note::
|
|
These APIs are deprecated in Microversion 2.43.
|
|
|
|
A *host action* is one that affects the physical host machine, as opposed to
|
|
actions that only affect the virtual servers running on that machine. There
|
|
are three 'power' actions that are supported: *startup*, *shutdown*, and
|
|
*reboot*. There are also two 'state' actions: enabling/disabling the host,
|
|
and setting the host into or out of maintenance mode. Of course, carrying
|
|
out these actions can affect running virtual servers on that host, so their
|
|
state will need to be considered before carrying out the host action. For
|
|
example, if you want to call the 'shutdown' action to turn off a host
|
|
machine, you might want to migrate any virtual servers on that host before
|
|
shutting down the host machine so that the virtual servers continue to be
|
|
available without interruption.
|
|
|
|
- **Hypervisors**
|
|
|
|
A hypervisor, or virtual machine monitor (VMM), is a piece of computer
|
|
software, firmware or hardware that creates and runs virtual machines.
|
|
|
|
In nova, each Host (see `Hosts`) runs a hypervisor. Administrators are able
|
|
to query the hypervisor for information, such as all the virtual servers
|
|
currently running, as well as detailed info about the hypervisor, such as
|
|
CPU, memory, or disk related configuration.
|
|
|
|
Currently nova-compute also supports Ironic and LXC, but they don't have
|
|
a hypervisor running.
|
|
|
|
- **Aggregates**
|
|
|
|
See :nova-doc:`Aggregates Developer Information <user/aggregates.html>`.
|
|
|
|
- **Migrations**
|
|
|
|
Migrations are the process where a virtual server is moved from one host to
|
|
another. Please see :doc:`server_concepts` for details about
|
|
moving servers.
|
|
|
|
Administrators are able to query the records in database for information
|
|
about migrations. For example, they can determine the source and
|
|
destination hosts, type of migration, or changes in the server's flavor.
|
|
|
|
Relationship with Volume API
|
|
============================
|
|
|
|
Here we discuss about Cinder's API and how Nova users volume UUIDs.
|
|
|
|
TODO - add more details.
|
|
|
|
Relationship with Image API
|
|
===========================
|
|
|
|
Here we discuss about Glance's API and how Nova uses image UUIDs.
|
|
We also discuss how Nova proxies setting image metadata.
|
|
|
|
TODO - add more details.
|
|
|
|
Interactions with neutron and nova-network (deprecated)
|
|
=======================================================
|
|
|
|
We talk about how networking can be provided be either neutron or
|
|
nova-network (deprecated).
|
|
|
|
Here we discuss about Neutron's API and how Nova users port UUIDs.
|
|
We also discuss Nova automatically creating ports, proxying security groups,
|
|
and proxying floating IPs. Also talk about the APIs we do not proxy.
|
|
|
|
TODO - add more details.
|