1f67ce2496
Introduce API microversion 2.88, which makes the following changes to a number of 'os-hypervisors'. Specifically, the following fields are dropped from both the '/os-hypervisors/detail' (detailed list) and '/os-hypervisors/{hypervisor_id}' (show) APIs: - current_workload - cpu_info - vcpus - vcpus_used - free_disk_gb - local_gb - local_gb_used - disk_available_least - free_ram_mb - memory_mb - memory_mb_used - running_vms In addition, the '/os-hypervisors/statistics' API, which provided a summary of the above stats but for all hypervisors in the deployment, is dropped entirely. Finally, the '/os-hypervisors/{hypervisor}/uptime' API, which provided a similar response to the '/os-hypervisors/{hypervisor}' API but with an additional 'uptime' field, has been removed in favour of including this field in the primary '/os-hypervisors/{hypervisor}' API. A small tweak to 'tox.ini' that allows us to share some venvs is included. Part of blueprint modernize-os-hypervisors-api Change-Id: I515e484ade6c6455f82a3067940a418a0d7d965a Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
432 lines
12 KiB
ReStructuredText
432 lines
12 KiB
ReStructuredText
.. -*- rst -*-
|
|
|
|
.. _os-hypervisors:
|
|
|
|
==============================
|
|
Hypervisors (os-hypervisors)
|
|
==============================
|
|
|
|
Lists all hypervisors, shows summary statistics for all hypervisors over
|
|
all compute nodes, shows details for a hypervisor, shows the uptime
|
|
for a hypervisor, lists all servers on hypervisors that match the given
|
|
``hypervisor_hostname_pattern`` or searches for hypervisors by the given
|
|
``hypervisor_hostname_pattern``.
|
|
|
|
|
|
List Hypervisors
|
|
================
|
|
|
|
.. rest_method:: GET /os-hypervisors
|
|
|
|
Lists hypervisors.
|
|
|
|
Policy defaults enable only users with the administrative role to perform
|
|
this operation. Cloud providers can change these permissions through
|
|
the ``policy.json`` file.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: badRequest(400), unauthorized(401), forbidden(403)
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- limit: hypervisor_limit
|
|
- marker: hypervisor_marker
|
|
- marker: hypervisor_marker_uuid
|
|
- hypervisor_hostname_pattern: hypervisor_hostname_pattern_query
|
|
- with_servers: hypervisor_with_servers_query
|
|
|
|
Response
|
|
--------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisors: hypervisors
|
|
- hypervisor_hostname: hypervisor_hostname
|
|
- id: hypervisor_id_body
|
|
- id: hypervisor_id_body_uuid
|
|
- state: hypervisor_state
|
|
- status: hypervisor_status
|
|
- hypervisor_links: hypervisor_links
|
|
- servers: hypervisor_servers
|
|
- servers.uuid: hypervisor_servers_uuid
|
|
- servers.name: hypervisor_servers_name
|
|
|
|
**Example List Hypervisors (v2.33): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.33/hypervisors-list-resp.json
|
|
:language: javascript
|
|
|
|
**Example List Hypervisors With Servers (v2.53): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.53/hypervisors-with-servers-resp.json
|
|
:language: javascript
|
|
|
|
|
|
List Hypervisors Details
|
|
========================
|
|
|
|
.. rest_method:: GET /os-hypervisors/detail
|
|
|
|
Lists hypervisors details.
|
|
|
|
Policy defaults enable only users with the administrative role to perform
|
|
this operation. Cloud providers can change these permissions through
|
|
the ``policy.json`` file.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: badRequest(400), unauthorized(401), forbidden(403)
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- limit: hypervisor_limit
|
|
- marker: hypervisor_marker
|
|
- marker: hypervisor_marker_uuid
|
|
- hypervisor_hostname_pattern: hypervisor_hostname_pattern_query
|
|
- with_servers: hypervisor_with_servers_query
|
|
|
|
Response
|
|
--------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisors: hypervisors
|
|
- cpu_info: cpu_info
|
|
- current_workload: current_workload
|
|
- status: hypervisor_status
|
|
- state: hypervisor_state
|
|
- disk_available_least: disk_available_least
|
|
- host_ip: host_ip
|
|
- free_disk_gb: hypervisor_free_disk_gb
|
|
- free_ram_mb: free_ram_mb
|
|
- hypervisor_hostname: hypervisor_hostname
|
|
- hypervisor_type: hypervisor_type_body
|
|
- hypervisor_version: hypervisor_version
|
|
- id: hypervisor_id_body
|
|
- id: hypervisor_id_body_uuid
|
|
- local_gb: local_gb
|
|
- local_gb_used: local_gb_used
|
|
- memory_mb: memory_mb
|
|
- memory_mb_used: memory_mb_used
|
|
- running_vms: running_vms
|
|
- servers: hypervisor_servers
|
|
- servers.uuid: hypervisor_servers_uuid
|
|
- servers.name: hypervisor_servers_name
|
|
- service: hypervisor_service
|
|
- service.host: host_name_body
|
|
- service.id: service_id_body_2_52
|
|
- service.id: service_id_body_2_53
|
|
- service.disabled_reason: service_disable_reason
|
|
- uptime: hypervisor_uptime
|
|
- vcpus: hypervisor_vcpus
|
|
- vcpus_used: hypervisor_vcpus_used
|
|
- hypervisor_links: hypervisor_links
|
|
|
|
**Example List Hypervisors Details (v2.33): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.33/hypervisors-detail-resp.json
|
|
:language: javascript
|
|
|
|
**Example List Hypervisors Details (v2.53): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.53/hypervisors-detail-resp.json
|
|
:language: javascript
|
|
|
|
**Example List Hypervisors Details (v2.88): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.88/hypervisors-detail-resp.json
|
|
:language: javascript
|
|
|
|
|
|
Show Hypervisor Statistics (DEPRECATED)
|
|
=======================================
|
|
|
|
.. rest_method:: GET /os-hypervisors/statistics
|
|
max_version: 2.87
|
|
|
|
Shows summary statistics for all enabled hypervisors over all compute nodes.
|
|
|
|
.. warning::
|
|
|
|
This API is deprecated and will fail with HTTP 404 starting with microversion
|
|
2.88. Use placement to get information on resource usage across hypervisors.
|
|
|
|
Policy defaults enable only users with the administrative role to perform
|
|
this operation. Cloud providers can change these permissions through
|
|
the ``policy.json`` file.
|
|
|
|
.. note::
|
|
|
|
As noted, some of the parameters in the response representing totals do not
|
|
take allocation ratios into account. This can result in a disparity between
|
|
the totals and the usages. A more accurate representation of state can be
|
|
obtained using `placement`__.
|
|
|
|
__ https://docs.openstack.org/api-ref/placement/#list-resource-provider-usages
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: unauthorized(401), forbidden(403), itemNotFound(404)
|
|
|
|
Response
|
|
--------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisor_statistics: hypervisor_statistics
|
|
- count: hypervisor_count
|
|
- current_workload: current_workload_total
|
|
- disk_available_least: disk_available_least_total
|
|
- free_disk_gb: hypervisor_free_disk_gb_total
|
|
- free_ram_mb: free_ram_mb_total
|
|
- local_gb: local_gb_total
|
|
- local_gb_used: local_gb_used_total
|
|
- memory_mb: memory_mb_total
|
|
- memory_mb_used: memory_mb_used_total
|
|
- running_vms: running_vms_total
|
|
- vcpus: hypervisor_vcpus_total
|
|
- vcpus_used: hypervisor_vcpus_used_total
|
|
|
|
**Example Show Hypervisor Statistics: JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/hypervisors-statistics-resp.json
|
|
:language: javascript
|
|
|
|
|
|
Show Hypervisor Details
|
|
=======================
|
|
|
|
.. rest_method:: GET /os-hypervisors/{hypervisor_id}
|
|
|
|
Shows details for a given hypervisor.
|
|
|
|
Policy defaults enable only users with the administrative role to perform
|
|
this operation. Cloud providers can change these permissions through
|
|
the ``policy.json`` file.
|
|
|
|
.. note::
|
|
|
|
As noted, some of the parameters in the response representing totals do not
|
|
take allocation ratios into account. This can result in a disparity between
|
|
the totals and the usages. A more accurate representation of state can be
|
|
obtained using `placement`__.
|
|
|
|
__ https://docs.openstack.org/api-ref/placement/#show-resource-provider-usages
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: badRequest(400), unauthorized(401), forbidden(403), itemNotFound(404)
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisor_id: hypervisor_id
|
|
- hypervisor_id: hypervisor_id_uuid
|
|
- with_servers: hypervisor_with_servers_query
|
|
|
|
Response
|
|
--------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisor: hypervisor
|
|
- cpu_info: cpu_info
|
|
- state: hypervisor_state
|
|
- status: hypervisor_status
|
|
- current_workload: current_workload
|
|
- disk_available_least: disk_available_least
|
|
- host_ip: host_ip
|
|
- free_disk_gb: hypervisor_free_disk_gb
|
|
- free_ram_mb: free_ram_mb
|
|
- hypervisor_hostname: hypervisor_hostname
|
|
- hypervisor_type: hypervisor_type_body
|
|
- hypervisor_version: hypervisor_version
|
|
- id: hypervisor_id_body
|
|
- id: hypervisor_id_body_uuid
|
|
- local_gb: local_gb
|
|
- local_gb_used: local_gb_used
|
|
- memory_mb: memory_mb
|
|
- memory_mb_used: memory_mb_used
|
|
- running_vms: running_vms
|
|
- servers: hypervisor_servers
|
|
- servers.uuid: hypervisor_servers_uuid
|
|
- servers.name: hypervisor_servers_name
|
|
- service: hypervisor_service
|
|
- service.host: host_name_body
|
|
- service.id: service_id_body_2_52
|
|
- service.id: service_id_body_2_53
|
|
- service.disabled_reason: service_disable_reason
|
|
- uptime: hypervisor_uptime
|
|
- vcpus: hypervisor_vcpus
|
|
- vcpus_used: hypervisor_vcpus_used
|
|
|
|
**Example Show Hypervisor Details (v2.28): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.28/hypervisors-show-resp.json
|
|
:language: javascript
|
|
|
|
**Example Show Hypervisor Details With Servers (v2.53): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.53/hypervisors-show-with-servers-resp.json
|
|
:language: javascript
|
|
|
|
**Example Show Hypervisors Details (v2.88): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.88/hypervisors-show-with-servers-resp.json
|
|
:language: javascript
|
|
|
|
|
|
Show Hypervisor Uptime (DEPRECATED)
|
|
===================================
|
|
|
|
.. rest_method:: GET /os-hypervisors/{hypervisor_id}/uptime
|
|
max_version: 2.87
|
|
|
|
Shows the uptime for a given hypervisor.
|
|
|
|
.. warning::
|
|
|
|
This API is deprecated and will fail with HTTP 404 starting with
|
|
microversion 2.88. Use `Show Hypervisor Details`_ with microversion 2.88
|
|
and later to get this information.
|
|
|
|
Policy defaults enable only users with the administrative role to perform
|
|
this operation. Cloud providers can change these permissions through
|
|
the ``policy.json`` file.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: badRequest(400), unauthorized(401), forbidden(403), itemNotFound(404), NotImplemented(501)
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisor_id: hypervisor_id
|
|
- hypervisor_id: hypervisor_id_uuid
|
|
|
|
Response
|
|
--------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisor: hypervisor
|
|
- hypervisor_hostname: hypervisor_hostname
|
|
- id: hypervisor_id_body
|
|
- id: hypervisor_id_body_uuid
|
|
- state: hypervisor_state
|
|
- status: hypervisor_status
|
|
- uptime: uptime
|
|
|
|
**Example Show Hypervisor Uptime: JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/hypervisors-uptime-resp.json
|
|
:language: javascript
|
|
|
|
**Example Show Hypervisor Uptime (v2.53): JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/v2.53/hypervisors-uptime-resp.json
|
|
:language: javascript
|
|
|
|
|
|
Search Hypervisor (DEPRECATED)
|
|
==============================
|
|
|
|
.. rest_method:: GET /os-hypervisors/{hypervisor_hostname_pattern}/search
|
|
max_version: 2.52
|
|
|
|
Search hypervisor by a given hypervisor host name or portion of it.
|
|
|
|
.. warning:: This API is deprecated starting with microversion 2.53. Use
|
|
`List Hypervisors`_ with the ``hypervisor_hostname_pattern`` query
|
|
parameter with microversion 2.53 and later.
|
|
|
|
Policy defaults enable only users with the administrative role to perform
|
|
this operation. Cloud providers can change these permissions through
|
|
the ``policy.json`` file.
|
|
|
|
Normal response code: 200
|
|
|
|
Error response codes: unauthorized(401), forbidden(403), itemNotFound(404)
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisor_hostname_pattern: hypervisor_hostname_pattern
|
|
|
|
Response
|
|
--------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisors: hypervisors
|
|
- hypervisor_hostname: hypervisor_hostname
|
|
- id: hypervisor_id_body_no_version
|
|
- state: hypervisor_state
|
|
- status: hypervisor_status
|
|
|
|
**Example Search Hypervisor: JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/hypervisors-search-resp.json
|
|
:language: javascript
|
|
|
|
|
|
List Hypervisor Servers (DEPRECATED)
|
|
====================================
|
|
|
|
.. rest_method:: GET /os-hypervisors/{hypervisor_hostname_pattern}/servers
|
|
max_version: 2.52
|
|
|
|
List all servers belong to each hypervisor whose host name is matching
|
|
a given hypervisor host name or portion of it.
|
|
|
|
.. warning:: This API is deprecated starting with microversion 2.53. Use
|
|
`List Hypervisors`_ with the ``hypervisor_hostname_pattern`` and
|
|
``with_servers`` query parameters with microversion 2.53 and later.
|
|
|
|
Policy defaults enable only users with the administrative role to perform
|
|
this operation. Cloud providers can change these permissions through
|
|
the ``policy.json`` file.
|
|
|
|
Normal response code: 200
|
|
|
|
Error response codes: unauthorized(401), forbidden(403), itemNotFound(404)
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisor_hostname_pattern: hypervisor_hostname_pattern
|
|
|
|
Response
|
|
--------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- hypervisors: hypervisors
|
|
- hypervisor_hostname: hypervisor_hostname
|
|
- id: hypervisor_id_body_no_version
|
|
- state: hypervisor_state
|
|
- status: hypervisor_status
|
|
- servers: servers
|
|
- servers.uuid: server_uuid
|
|
- servers.name: server_name
|
|
|
|
**Example List Hypervisor Servers: JSON response**
|
|
|
|
.. literalinclude:: ../../doc/api_samples/os-hypervisors/hypervisors-with-servers-resp.json
|
|
:language: javascript
|