Update docs layout
* Explain these docs are for trunk (copied from ironic) * All the docs in this repo are meant to be developer docs, so having a devref inside of the docs is redundant and just makes the docs more complicated to navigate. Move everything out of the devref folder and link to everything from main index. * Move man pages into separate section. The man pages are pretty sparse * right now, we should either make them useful or just delete them * Remove dead docs from unused_docs list in doc/source/conf.py * Shuffle docs landing page, move common referees to the top (API, hypervisor support matrix), Add a introduction section and more. The hope is the updated layout makes this document easier to navigate. * Use maxdepth of 1 * Rename a few sections with what are hopefully better names The next step is to prune out outdated documents and further cleanup this page. Change-Id: Iff453e47ccc902a0e72b1a5f6ce1ee939ff3a1a0
This commit is contained in:
parent
4e122194e1
commit
a1e8fc6dd9
@ -84,9 +84,6 @@ version = version_info.version_string()
|
|||||||
|
|
||||||
# List of documents that shouldn't be included in the build.
|
# List of documents that shouldn't be included in the build.
|
||||||
unused_docs = [
|
unused_docs = [
|
||||||
'api_ext/rst_extension_template',
|
|
||||||
'vmwareapi_readme',
|
|
||||||
'installer',
|
|
||||||
]
|
]
|
||||||
|
|
||||||
# List of directories, relative to source directory, that shouldn't be searched
|
# List of directories, relative to source directory, that shouldn't be searched
|
||||||
|
@ -1,94 +0,0 @@
|
|||||||
..
|
|
||||||
Copyright 2010-2011 United States Government as represented by the
|
|
||||||
Administrator of the National Aeronautics and Space Administration.
|
|
||||||
All Rights Reserved.
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
not use this file except in compliance with the License. You may obtain
|
|
||||||
a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
License for the specific language governing permissions and limitations
|
|
||||||
under the License.
|
|
||||||
|
|
||||||
Developer Guide
|
|
||||||
===============
|
|
||||||
|
|
||||||
In this section you will find information on Nova's lower level programming APIs.
|
|
||||||
|
|
||||||
|
|
||||||
Programming HowTos and Tutorials
|
|
||||||
--------------------------------
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 3
|
|
||||||
|
|
||||||
development.environment
|
|
||||||
unit_tests
|
|
||||||
addmethod.openstackapi
|
|
||||||
gmr
|
|
||||||
api_plugins
|
|
||||||
api_microversions
|
|
||||||
|
|
||||||
Background Concepts for Nova
|
|
||||||
----------------------------
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 3
|
|
||||||
|
|
||||||
architecture
|
|
||||||
aggregates
|
|
||||||
cells
|
|
||||||
threading
|
|
||||||
vmstates
|
|
||||||
i18n
|
|
||||||
filter_scheduler
|
|
||||||
rpc
|
|
||||||
hooks
|
|
||||||
upgrade
|
|
||||||
policy_enforcement
|
|
||||||
|
|
||||||
Development policies
|
|
||||||
--------------------
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 3
|
|
||||||
|
|
||||||
kilo.blueprints
|
|
||||||
policies
|
|
||||||
project_scope
|
|
||||||
|
|
||||||
Testing guides
|
|
||||||
--------------
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 3
|
|
||||||
|
|
||||||
testing/libvirt-numa
|
|
||||||
testing/serial-console
|
|
||||||
|
|
||||||
Other Resources
|
|
||||||
---------------
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 3
|
|
||||||
|
|
||||||
launchpad
|
|
||||||
gerrit
|
|
||||||
jenkins
|
|
||||||
|
|
||||||
Module Reference
|
|
||||||
----------------
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 3
|
|
||||||
|
|
||||||
services
|
|
||||||
|
|
||||||
|
|
||||||
Indices and tables
|
|
||||||
------------------
|
|
||||||
|
|
||||||
* :ref:`genindex`
|
|
||||||
* :ref:`modindex`
|
|
||||||
* :ref:`search`
|
|
||||||
|
|
@ -8,7 +8,7 @@ only working with Compute Nodes.
|
|||||||
Filtering
|
Filtering
|
||||||
---------
|
---------
|
||||||
|
|
||||||
.. image:: ../images/filteringWorkflow1.png
|
.. image:: ./images/filteringWorkflow1.png
|
||||||
|
|
||||||
During its work Filter Scheduler firstly makes dictionary of unfiltered hosts,
|
During its work Filter Scheduler firstly makes dictionary of unfiltered hosts,
|
||||||
then filters them using filter properties and finally chooses hosts for the
|
then filters them using filter properties and finally chooses hosts for the
|
||||||
@ -370,7 +370,7 @@ so subsequent selections can adjust accordingly. It is useful if the customer
|
|||||||
asks for the some large amount of instances, because weight is computed for
|
asks for the some large amount of instances, because weight is computed for
|
||||||
each instance requested.
|
each instance requested.
|
||||||
|
|
||||||
.. image:: ../images/filteringWorkflow2.png
|
.. image:: ./images/filteringWorkflow2.png
|
||||||
|
|
||||||
In the end Filter Scheduler sorts selected hosts by their weight and provisions
|
In the end Filter Scheduler sorts selected hosts by their weight and provisions
|
||||||
instances on them.
|
instances on them.
|
@ -15,49 +15,130 @@
|
|||||||
License for the specific language governing permissions and limitations
|
License for the specific language governing permissions and limitations
|
||||||
under the License.
|
under the License.
|
||||||
|
|
||||||
|
==========================================
|
||||||
Welcome to Nova's developer documentation!
|
Welcome to Nova's developer documentation!
|
||||||
==========================================
|
==========================================
|
||||||
|
|
||||||
Nova is an OpenStack project designed to provide power massively scalable, on
|
Nova is an OpenStack project designed to provide power massively scalable, on
|
||||||
demand, self service access to compute resources.
|
demand, self service access to compute resources.
|
||||||
|
|
||||||
|
The developer documentation provided here is continually kept up-to-date
|
||||||
|
based on the latest code, and may not represent the state of the project at
|
||||||
|
any specific prior release.
|
||||||
|
|
||||||
.. note:: This is documentation for developers, if you are looking for more
|
.. note:: This is documentation for developers, if you are looking for more
|
||||||
general documentation including API, install, operator and user
|
general documentation including API, install, operator and user
|
||||||
guides see `docs.openstack.org`_
|
guides see `docs.openstack.org`_
|
||||||
|
|
||||||
.. _`docs.openstack.org`: https://docs.openstack.org
|
.. _`docs.openstack.org`: https://docs.openstack.org
|
||||||
|
|
||||||
|
Compute API References
|
||||||
|
=======================
|
||||||
|
|
||||||
|
* `v2.1 (CURRENT)`_
|
||||||
|
* `v2 (SUPPORTED)`_ and `v2 extensions (SUPPORTED)`_ (Will be deprecated in
|
||||||
|
the near future.)
|
||||||
|
|
||||||
Developer Docs
|
Local copy of v2 docs:
|
||||||
==============
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 1
|
|
||||||
|
|
||||||
devref/index
|
|
||||||
man/index
|
|
||||||
support-matrix
|
|
||||||
devref/project_scope
|
|
||||||
|
|
||||||
Compute API v2
|
|
||||||
==============
|
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
v2/index
|
v2/index
|
||||||
|
|
||||||
API Extensions
|
|
||||||
==============
|
|
||||||
|
|
||||||
Go to the `API Complete Reference v2.1 (CURRENT)`_ for information about the Compute API.
|
.. _`v2.1 (CURRENT)`: http://developer.openstack.org/api-ref-compute-v2.1.html
|
||||||
We still support the older `API Complete Reference v2 (SUPPORTED)`_ and its extensions
|
.. _`v2 (SUPPORTED)`: http://developer.openstack.org/api-ref-compute-v2.html
|
||||||
`API Complete Reference v2 extensions (SUPPORTED)`_
|
.. _`v2 extensions (SUPPORTED)`: http://developer.openstack.org/api-ref-compute-v2-ext.html
|
||||||
|
|
||||||
.. _`API Complete Reference v2.1 (CURRENT)`: http://developer.openstack.org/api-ref-compute-v2.1.html
|
|
||||||
.. _`API Complete Reference v2 (SUPPORTED)`: http://developer.openstack.org/api-ref-compute-v2.html
|
|
||||||
.. _`API Complete Reference v2 extensions (SUPPORTED)`: http://developer.openstack.org/api-ref-compute-v2-ext.html
|
Hypervisor Support Matrix
|
||||||
|
=========================
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
support-matrix
|
||||||
|
|
||||||
|
Developer Guide
|
||||||
|
===============
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
-------------
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
architecture
|
||||||
|
project_scope
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
development.environment
|
||||||
|
unit_tests
|
||||||
|
launchpad
|
||||||
|
gerrit
|
||||||
|
jenkins
|
||||||
|
|
||||||
|
APIs Development
|
||||||
|
----------------
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
addmethod.openstackapi
|
||||||
|
api_plugins
|
||||||
|
api_microversions
|
||||||
|
policy_enforcement
|
||||||
|
|
||||||
|
Concepts
|
||||||
|
---------
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
aggregates
|
||||||
|
cells
|
||||||
|
threading
|
||||||
|
vmstates
|
||||||
|
i18n
|
||||||
|
filter_scheduler
|
||||||
|
rpc
|
||||||
|
hooks
|
||||||
|
upgrade
|
||||||
|
|
||||||
|
Development policies
|
||||||
|
--------------------
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
kilo.blueprints
|
||||||
|
policies
|
||||||
|
|
||||||
|
Advanced testing and guides
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
gmr
|
||||||
|
testing/libvirt-numa
|
||||||
|
testing/serial-console
|
||||||
|
|
||||||
|
Man Pages
|
||||||
|
----------
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
man/index
|
||||||
|
|
||||||
|
Module Reference
|
||||||
|
----------------
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
|
||||||
|
services
|
||||||
|
|
||||||
Indices and tables
|
Indices and tables
|
||||||
==================
|
==================
|
||||||
|
@ -23,7 +23,7 @@ In this section you will find information on Nova's command line utilities.
|
|||||||
Reference
|
Reference
|
||||||
---------
|
---------
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 3
|
:maxdepth: 1
|
||||||
|
|
||||||
nova-all
|
nova-all
|
||||||
nova-api-ec2
|
nova-api-ec2
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
..
|
.
|
||||||
Copyright (c) 2010 Citrix Systems, Inc.
|
Copyright (c) 2010 Citrix Systems, Inc.
|
||||||
All Rights Reserved.
|
All Rights Reserved.
|
||||||
|
|
||||||
@ -25,7 +25,7 @@ AMQP is the messaging technology chosen by the OpenStack cloud. The AMQP broker
|
|||||||
|
|
||||||
Nova uses direct, fanout, and topic-based exchanges. The architecture looks like the one depicted in the figure below:
|
Nova uses direct, fanout, and topic-based exchanges. The architecture looks like the one depicted in the figure below:
|
||||||
|
|
||||||
.. image:: ../images/rpc/arch.png
|
.. image:: ./images/rpc/arch.png
|
||||||
:width: 60%
|
:width: 60%
|
||||||
|
|
||||||
..
|
..
|
||||||
@ -47,7 +47,7 @@ Figure 2 shows the following internal elements:
|
|||||||
* Direct Exchange: this is a routing table that is created during rpc.call operations; there are many instances of this kind of exchange throughout the life-cycle of a message broker node, one for each rpc.call invoked.
|
* Direct Exchange: this is a routing table that is created during rpc.call operations; there are many instances of this kind of exchange throughout the life-cycle of a message broker node, one for each rpc.call invoked.
|
||||||
* Queue Element: A Queue is a message bucket. Messages are kept in the queue until a Consumer (either Topic or Direct Consumer) connects to the queue and fetch it. Queues can be shared or can be exclusive. Queues whose routing key is 'topic' are shared amongst Workers of the same personality.
|
* Queue Element: A Queue is a message bucket. Messages are kept in the queue until a Consumer (either Topic or Direct Consumer) connects to the queue and fetch it. Queues can be shared or can be exclusive. Queues whose routing key is 'topic' are shared amongst Workers of the same personality.
|
||||||
|
|
||||||
.. image:: ../images/rpc/rabt.png
|
.. image:: ./images/rpc/rabt.png
|
||||||
:width: 60%
|
:width: 60%
|
||||||
|
|
||||||
..
|
..
|
||||||
@ -62,7 +62,7 @@ The diagram below shows the message flow during an rpc.call operation:
|
|||||||
3. once the task is completed, a Direct Publisher is allocated to send the response message to the queuing system.
|
3. once the task is completed, a Direct Publisher is allocated to send the response message to the queuing system.
|
||||||
4. once the message is dispatched by the exchange, it is fetched by the Direct Consumer dictated by the routing key (such as 'msg_id') and passed to the Invoker.
|
4. once the message is dispatched by the exchange, it is fetched by the Direct Consumer dictated by the routing key (such as 'msg_id') and passed to the Invoker.
|
||||||
|
|
||||||
.. image:: ../images/rpc/flow1.png
|
.. image:: ./images/rpc/flow1.png
|
||||||
:width: 60%
|
:width: 60%
|
||||||
|
|
||||||
..
|
..
|
||||||
@ -75,7 +75,7 @@ The diagram below shows the message flow during an rpc.cast operation:
|
|||||||
1. A Topic Publisher is instantiated to send the message request to the queuing system.
|
1. A Topic Publisher is instantiated to send the message request to the queuing system.
|
||||||
2. Once the message is dispatched by the exchange, it is fetched by the Topic Consumer dictated by the routing key (such as 'topic') and passed to the Worker in charge of the task.
|
2. Once the message is dispatched by the exchange, it is fetched by the Topic Consumer dictated by the routing key (such as 'topic') and passed to the Worker in charge of the task.
|
||||||
|
|
||||||
.. image:: ../images/rpc/flow2.png
|
.. image:: ./images/rpc/flow2.png
|
||||||
:width: 60%
|
:width: 60%
|
||||||
|
|
||||||
..
|
..
|
||||||
@ -100,7 +100,7 @@ The figure below shows the status of a RabbitMQ node after Nova components' boot
|
|||||||
5. scheduler.phantom (phantom is hostname)
|
5. scheduler.phantom (phantom is hostname)
|
||||||
6. scheduler
|
6. scheduler
|
||||||
|
|
||||||
.. image:: ../images/rpc/state.png
|
.. image:: ./images/rpc/state.png
|
||||||
:width: 60%
|
:width: 60%
|
||||||
|
|
||||||
..
|
..
|
@ -172,9 +172,9 @@ task states for various commands issued by the user:
|
|||||||
shelved_offloaded -> unshelve
|
shelved_offloaded -> unshelve
|
||||||
}
|
}
|
||||||
|
|
||||||
.. image:: ../images/PowerStates1.png
|
.. image:: ./images/PowerStates1.png
|
||||||
|
|
||||||
.. image:: ../images/PowerStates2.png
|
.. image:: ./images/PowerStates2.png
|
||||||
|
|
||||||
|
|
||||||
Create instance states
|
Create instance states
|
||||||
@ -184,4 +184,4 @@ The following diagram shows the sequence of VM states, task states, and
|
|||||||
power states when a new VM instance is created.
|
power states when a new VM instance is created.
|
||||||
|
|
||||||
|
|
||||||
.. image:: ../images/run_instance_walkthrough.png
|
.. image:: ./images/run_instance_walkthrough.png
|
Loading…
Reference in New Issue
Block a user