3ca32b8434
Change capitalization as discussed on openstack-docs mailing list. Change-Id: I2ad81bffbd59bdd8b908664bb0a1ee16da1bf7ae
272 lines
11 KiB
XML
272 lines
11 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
|
<section xmlns="http://docbook.org/ns/docbook"
|
|
xmlns:xi="http://www.w3.org/2001/XInclude"
|
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
version="5.0"
|
|
xml:id="compute-service">
|
|
<title>OpenStack Compute</title>
|
|
<para>Use OpenStack Compute to host and manage cloud computing
|
|
systems. OpenStack Compute is a major part of an
|
|
Infrastructure-as-a-Service (IaaS) system. The main modules are
|
|
implemented in Python.</para>
|
|
<para>OpenStack Compute interacts with OpenStack Identity for
|
|
authentication, OpenStack Image service for disk and server
|
|
images, and OpenStack dashboard for the user and administrative
|
|
interface. Image access is limited by projects, and by users;
|
|
quotas are limited per project (the number of instances, for
|
|
example). OpenStack Compute can scale horizontally on standard
|
|
hardware, and download images to launch instances.</para>
|
|
<para>OpenStack Compute consists of the following areas and their
|
|
components:</para>
|
|
<variablelist>
|
|
<title>API</title>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-api</systemitem>
|
|
service</term>
|
|
<listitem>
|
|
<para>Accepts and responds to end user compute API calls. The
|
|
service supports the OpenStack Compute API, the Amazon EC2
|
|
API, and a special Admin API for privileged users to perform
|
|
administrative actions. It enforces some policies and
|
|
initiates most orchestration activities, such as running an
|
|
instance.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-api-metadata</systemitem>
|
|
service</term>
|
|
<listitem>
|
|
<para>Accepts metadata requests from instances. The
|
|
<systemitem class="service">nova-api-metadata</systemitem>
|
|
service is generally used when you run in multi-host mode
|
|
with <systemitem class="service">nova-network</systemitem>
|
|
installations. For details, see <link
|
|
xlink:href="http://docs.openstack.org/admin-guide-cloud/content/section_metadata-service.html"
|
|
>Metadata service</link> in the <citetitle>OpenStack Cloud
|
|
Administrator Guide</citetitle>.</para>
|
|
<para>On Debian systems, it is included in the <systemitem
|
|
class="service">nova-api</systemitem> package, and can be
|
|
selected through <package>debconf</package>.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
<variablelist>
|
|
<title>Compute core</title>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-compute</systemitem>
|
|
service</term>
|
|
<listitem>
|
|
<para>A worker daemon that creates and terminates virtual
|
|
machine instances through hypervisor APIs. For
|
|
example:</para>
|
|
<itemizedlist>
|
|
<listitem>
|
|
<para>XenAPI for XenServer/XCP</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>libvirt for KVM or QEMU</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>VMwareAPI for VMware</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
<para>Processing is fairly complex. Basically, the daemon
|
|
accepts actions from the queue and performs a series of
|
|
system commands such as launching a KVM instance and
|
|
updating its state in the database.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-scheduler</systemitem>
|
|
service</term>
|
|
<listitem>
|
|
<para>Takes a virtual machine instance request from the queue
|
|
and determines on which compute server host it runs.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-conductor</systemitem>
|
|
module</term>
|
|
<listitem>
|
|
<para>Mediates interactions between the <systemitem
|
|
class="service">nova-compute</systemitem> service and the
|
|
database. It eliminates direct accesses to the cloud
|
|
database made by the <systemitem class="service"
|
|
>nova-compute</systemitem> service. The <systemitem
|
|
class="service">nova-conductor</systemitem> module scales
|
|
horizontally. However, do not deploy it on nodes where the
|
|
<systemitem class="service">nova-compute</systemitem>
|
|
service runs. For more information, see <link
|
|
xlink:href="http://russellbryantnet.wordpress.com/2012/11/19/a-new-nova-service-nova-conductor/"
|
|
>A new Nova service: nova-conductor</link>.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-cert</systemitem>
|
|
module</term>
|
|
<listitem>
|
|
<para>A server daemon that serves the Nova Cert service for X509
|
|
certificates. Used to generate certificates for
|
|
<command>euca-bundle-image</command>. Only needed for the EC2 API.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
</variablelist>
|
|
<variablelist>
|
|
<title>Networking for VMs</title>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-network</systemitem>
|
|
worker daemon</term>
|
|
<listitem>
|
|
<para>Similar to the <systemitem class="service"
|
|
>nova-compute</systemitem> service, accepts networking
|
|
tasks from the queue and manipulates the network. Performs
|
|
tasks such as setting up bridging interfaces or changing
|
|
IPtables rules.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
<?hard-pagebreak?>
|
|
<variablelist>
|
|
<title>Console interface</title>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-consoleauth</systemitem>
|
|
daemon</term>
|
|
<listitem>
|
|
<para>Authorizes tokens for users that console proxies
|
|
provide. See <systemitem class="service"
|
|
>nova-novncproxy</systemitem> and <systemitem
|
|
class="service">nova-xvpnvcproxy</systemitem>. This
|
|
service must be running for console proxies to work. You can
|
|
run proxies of either type against a single <systemitem
|
|
class="service">nova-consoleauth</systemitem> service in a
|
|
cluster configuration. For information, see <link
|
|
xlink:href="http://docs.openstack.org/admin-guide-cloud/content/about-nova-consoleauth.html"
|
|
>About nova-consoleauth</link>.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-novncproxy</systemitem>
|
|
daemon</term>
|
|
<listitem>
|
|
<para>Provides a proxy for accessing running instances through
|
|
a VNC connection. Supports browser-based novnc
|
|
clients.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-spicehtml5proxy</systemitem>
|
|
daemon</term>
|
|
<listitem>
|
|
<para>Provides a proxy for accessing running instances through
|
|
a SPICE connection. Supports browser-based HTML5
|
|
client.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-xvpnvncproxy</systemitem>
|
|
daemon</term>
|
|
<listitem>
|
|
<para>Provides a proxy for accessing running instances through
|
|
a VNC connection. Supports an OpenStack-specific Java
|
|
client.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-cert</systemitem>
|
|
daemon</term>
|
|
<listitem>
|
|
<para>x509 certificates.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
<para os="debian">In Debian, a unique
|
|
<package>nova-consoleproxy</package> package provides the
|
|
<package>nova-novncproxy</package>,
|
|
<package>nova-spicehtml5proxy</package>, and
|
|
<package>nova-xvpvncproxy</package> packages. To select
|
|
packages, edit the
|
|
<filename>/etc/default/nova-consoleproxy</filename> file or use
|
|
the <package>debconf</package> interface. You can also manually
|
|
edit the <filename>/etc/default/nova-consoleproxy</filename> file,
|
|
and stop and start the console daemons.</para>
|
|
<variablelist>
|
|
<title>Image management (EC2 scenario)</title>
|
|
<varlistentry>
|
|
<term><systemitem class="service">nova-objectstore</systemitem>
|
|
daemon</term>
|
|
<listitem>
|
|
<para>An S3 interface for registering images with the
|
|
OpenStack Image service. Used primarily for installations
|
|
that must support euca2ools. The euca2ools tools talk to
|
|
<systemitem class="service">nova-objectstore</systemitem>
|
|
in <emphasis role="italic">S3 language</emphasis>, and
|
|
<systemitem class="service">nova-objectstore</systemitem>
|
|
translates S3 requests into Image service requests.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term>euca2ools client</term>
|
|
<listitem>
|
|
<para>A set of command-line interpreter commands for managing
|
|
cloud resources. Although it is not an OpenStack module, you
|
|
can configure <systemitem class="service"
|
|
>nova-api</systemitem> to support this EC2 interface. For
|
|
more information, see the <link
|
|
xlink:href="https://www.eucalyptus.com/docs/eucalyptus/3.4/index.html"
|
|
>Eucalyptus 3.4 Documentation</link>.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
<variablelist>
|
|
<title>Command-line clients and other interfaces</title>
|
|
<varlistentry>
|
|
<term>nova client</term>
|
|
<listitem>
|
|
<para>Enables users to submit commands as a tenant
|
|
administrator or end user.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
<variablelist>
|
|
<title>Other components</title>
|
|
<varlistentry>
|
|
<term>The queue</term>
|
|
<listitem>
|
|
<para>A central hub for passing messages between daemons.
|
|
Usually implemented with <link
|
|
xlink:href="http://www.rabbitmq.com/">RabbitMQ</link>, but
|
|
can be implemented with an AMQP message queue, such as <link
|
|
xlink:href="http://qpid.apache.org/">Apache Qpid</link> or
|
|
<link xlink:href="http://www.zeromq.org/">Zero
|
|
MQ</link>.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term>SQL database</term>
|
|
<listitem>
|
|
<para>Stores most build-time and run-time states for a cloud
|
|
infrastructure, including:</para>
|
|
<itemizedlist>
|
|
<listitem>
|
|
<para>Available instance types</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Instances in use</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Available networks</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Projects</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
<para>Theoretically, OpenStack Compute can support any
|
|
database that SQL-Alchemy supports. Common databases are
|
|
SQLite3 for test and development work, MySQL, and
|
|
PostgreSQL.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</section>
|