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:
Joe Gordon 2015-05-14 14:18:53 -07:00
parent 4e122194e1
commit a1e8fc6dd9
30 changed files with 114 additions and 130 deletions

View File

@ -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

View File

@ -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`

View File

@ -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.

View File

@ -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
================== ==================

View File

@ -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

View File

@ -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%
.. ..

View File

@ -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