Work on consolidating to Compute admin guide only

Removes identity admin manual and image admin manual as separate "books"
Changes index.html to go to "current" which is "trunk" and Diablo only if clicked
Changes compute admin manual to include identity information imported from keystone.openstack.org
Yes, still needs lots of work, just a starting point for consolidation.

Change-Id: I979107ad496ea3e06be613a899ba2d1f83cfa56f
This commit is contained in:
annegentle 2012-03-09 15:05:53 -06:00
parent 139f69473e
commit c1286e5772
36 changed files with 1349 additions and 4162 deletions

@ -1,233 +0,0 @@
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.openstack.docs</groupId>
<artifactId>openstack-guide</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>OpenStack Guides</name>
<!-- ################################################ -->
<!-- USE "mvn clean generate-sources" to run this POM -->
<!-- ################################################ -->
<profiles>
<profile>
<id>Rackspace Research Repositories</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<repositories>
<repository>
<id>rackspace-research</id>
<name>Rackspace Research Repository</name>
<url>http://maven.research.rackspacecloud.com/content/groups/public/</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>rackspace-research</id>
<name>Rackspace Research Repository</name>
<url>http://maven.research.rackspacecloud.com/content/groups/public/</url>
</pluginRepository>
</pluginRepositories>
</profile>
</profiles>
<build>
<resources>
<resource>
<directory>target/docbkx/pdf</directory>
<excludes>
<exclude>**/*.fo</exclude>
</excludes>
</resource>
</resources>
<plugins>
<plugin>
<groupId>com.rackspace.cloud.api</groupId>
<artifactId>clouddocs-maven-plugin</artifactId>
<version>1.0.9</version>
<executions>
<execution>
<id>goal1</id>
<goals>
<goal>generate-pdf</goal>
</goals>
<phase>generate-sources</phase>
<configuration>
<highlightSource>false</highlightSource>
<!-- The following elements sets the autonumbering of sections in output for chapter numbers but no numbered sections-->
<sectionAutolabel>0</sectionAutolabel>
<sectionLabelIncludesComponentLabel>0</sectionLabelIncludesComponentLabel>
</configuration>
</execution>
<execution>
<id>goal2</id>
<goals>
<goal>generate-webhelp</goal>
</goals>
<phase>generate-sources</phase>
<configuration>
<!-- These parameters only apply to webhelp -->
<enableDisqus>0</enableDisqus>
<disqusShortname>openstackdocs</disqusShortname>
<enableGoogleAnalytics>1</enableGoogleAnalytics>
<googleAnalyticsId>UA-17511903-6</googleAnalyticsId>
<generateToc>
appendix toc,title
article/appendix nop
article toc,title
book title,figure,table,example,equation
chapter toc,title
part toc,title
preface toc,title
qandadiv toc
qandaset toc
reference toc,title
set toc,title
</generateToc>
<!-- The following elements sets the autonumbering of sections in output for chapter numbers but no numbered sections-->
<sectionAutolabel>0</sectionAutolabel>
<sectionLabelIncludesComponentLabel>0</sectionLabelIncludesComponentLabel>
<postProcess>
<!-- Copies the figures to the correct location for webhelp -->
<copy todir="${basedir}/target/docbkx/webhelp/openstack-compute-admin/os-compute-adminguide/content/figures">
<fileset dir="${basedir}/src/docbkx/openstack-compute-admin/figures">
<include name="**/*.*" />
</fileset>
</copy>
<copy todir="${basedir}/target/docbkx/webhelp/openstack-image-service-admin/os-image-adminguide/content/figures">
<fileset dir="${basedir}/src/docbkx/openstack-image-service-admin/figures">
<include name="**/*.png" />
</fileset>
</copy>
<copy todir="${basedir}/target/docbkx/webhelp/openstack-object-storage-admin/os-objectstorage-adminguide/content/figures">
<fileset dir="${basedir}/src/docbkx/openstack-object-storage-admin/figures">
<include name="**/*.png" />
</fileset>
</copy>
<!-- Copies webhelp (HTML output) to desired URL location on docs.openstack.org -->
<copy todir="${basedir}/target/docbkx/webhelp/trunk/openstack-compute/admin/">
<fileset
dir="${basedir}/target/docbkx/webhelp/openstack-compute-admin/os-compute-adminguide/">
<include name="**/*" />
</fileset>
</copy>
<copy
todir="${basedir}/target/docbkx/webhelp/trunk/openstack-object-storage/admin">
<fileset
dir="${basedir}/target/docbkx/webhelp/openstack-object-storage-admin/os-objectstorage-adminguide/">
<include name="**/*" />
</fileset>
</copy>
<copy
todir="${basedir}/target/docbkx/webhelp/trunk/openstack-image-service/admin">
<fileset
dir="${basedir}/target/docbkx/webhelp/openstack-image-service-admin/os-image-adminguide/">
<include name="**/*" />
</fileset>
</copy>
<!--Moves PDFs to the needed placement -->
<move failonerror="false"
file="${basedir}/target/docbkx/pdf/openstack-compute-admin/os-compute-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-compute/admin/os-compute-adminguide-trunk.pdf"/>
<move failonerror="false"
file="${basedir}/target/docbkx/pdf/openstack-image-service-admin/os-image-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-image-service/admin/os-image-adminguide-trunk.pdf"/>
<move failonerror="false"
file="${basedir}/target/docbkx/pdf/openstack-object-storage-admin/os-objectstorage-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-object-storage/admin/os-objectstorage-adminguide-trunk.pdf"/>
<!--Deletes leftover uneeded directories -->
<delete dir="${basedir}/target/docbkx/webhelp/openstack-compute-admin"/>
<delete dir="${basedir}/target/docbkx/webhelp/openstack-object-storage-admin"/>
<delete dir="${basedir}/target/docbkx/webhelp/openstack-image-service-admin"/>
</postProcess>
</configuration>
</execution>
<!--<execution>
<id>goal3</id>
<goals>
<goal>generate-epub</goal>
</goals>
<phase>generate-sources</phase>
<configuration>
<highlightSource>true</highlightSource>
<!-\- The following elements sets the autonumbering of sections in output for chapter numbers but no numbered sections-\->
<sectionAutolabel>0</sectionAutolabel>
<sectionLabelIncludesComponentLabel>0</sectionLabelIncludesComponentLabel>
<postProcess>
<!-\- Copies the figures to the correct location for epub -\->
<mkdir dir="${basedir}/target/docbkx/epub/openstack-compute-admin/os-compute-adminguide/figures"/>
<copy todir="${basedir}/target/docbkx/epub/openstack-compute-admin/os-compute-adminguide/figures">
<fileset dir="${basedir}/src/docbkx/openstack-compute-admin/figures">
<include name="**/*.png" />
<include name="**/*.jpg" />
<include name="**/*.gif" />
</fileset>
</copy>
<copy todir="${basedir}/target/docbkx/epub/openstack-image-service-admin/os-image-adminguide/figures">
<fileset dir="${basedir}/src/docbkx/openstack-image-service-admin/figures">
<include name="**/*.png" />
</fileset>
</copy>
<copy todir="${basedir}/target/docbkx/epub/openstack-object-storage-admin/os-objectstorage-adminguide/figures">
<fileset dir="${basedir}/src/docbkx/openstack-object-storage-admin/figures">
<include name="**/*.png" />
</fileset>
</copy>
<!-\- Rezip now that the figures are in the correct location -\->
<zip
destfile="${basedir}/target/docbkx/webhelp/openstack-compute-admin/os-compute-adminguide/os-compute-adminguide.epub"
basedir="${basedir}/target/docbkx/epub/openstack-compute-admin/os-compute-adminguide/"
update="true"
excludes="**/*.epub"/>
<zip
destfile="${basedir}/target/docbkx/webhelp/openstack-image-service-admin/os-image-adminguide/os-image-adminguide.epub"
basedir="${basedir}/target/docbkx/epub/openstack-image-service-admin/os-image-adminguide/"
update="true"
excludes="**/*.epub"/>
<zip
destfile="${basedir}/target/docbkx/webhelp/openstack-object-service-admin/os-objectstorage-adminguide/os-objectstorage-adminguide.epub"
basedir="${basedir}/target/docbkx/epub/openstack-object-service-admin/os-objectstorage-adminguide/"
update="true"
excludes="**/*.epub"/>
</postProcess>
</configuration>
</execution>-->
</executions>
<configuration>
<!-- These parameters apply to pdf and webhelp -->
<xincludeSupported>true</xincludeSupported>
<sourceDirectory>src/docbkx</sourceDirectory>
<includes>
openstack-compute-admin/os-compute-adminguide.xml,
openstack-object-storage-admin/os-objectstorage-adminguide.xml,
openstack-image-service-admin/os-image-adminguide.xml
</includes>
<profileSecurity>reviewer</profileSecurity>
<branding>openstack</branding>
</configuration>
</plugin>
</plugins>
</build>
</project>

File diff suppressed because it is too large Load Diff

@ -50,7 +50,7 @@
<plugin>
<groupId>com.rackspace.cloud.api</groupId>
<artifactId>clouddocs-maven-plugin</artifactId>
<version>1.0.9</version>
<version>1.0.10</version>
<executions>
<execution>
<id>goal1</id>
@ -74,7 +74,7 @@
<configuration>
<!-- These parameters only apply to webhelp -->
<enableDisqus>1</enableDisqus>
<disqusShortname>openstackdocs</disqusShortname>
<disqusShortname>openstackcomputeapiprogrammer</disqusShortname>
<enableGoogleAnalytics>1</enableGoogleAnalytics>
<googleAnalyticsId>UA-17511903-6</googleAnalyticsId>
<generateToc>
@ -96,34 +96,31 @@
<postProcess>
<!-- Copies the figures to the correct location for webhelp -->
<copy todir="${basedir}/target/docbkx/webhelp/openstack-image-service-admin/os-image-adminguide/figures">
<!--<copy todir="${basedir}/target/docbkx/webhelp/trunk/openstack-compute/install/content/figures">
<fileset dir="${basedir}/figures">
<include name="**/*.png" />
<include name="**/*.*" />
</fileset>
</copy>
<!-- Copies webhelp (HTML output) to desired URL location on docs.openstack.org -->
</copy>-->
<!-- Copies webhelp (HTML output) to desired URL location on docs.openstack.org -->
<copy
todir="${basedir}/target/docbkx/webhelp/trunk/openstack-image-service/admin">
todir="${basedir}/target/docbkx/webhelp/api/openstack-compute/programmer">
<fileset
dir="${basedir}/target/docbkx/webhelp/openstack-image-service-admin/os-image-adminguide/">
dir="${basedir}/target/docbkx/webhelp/openstackapi-programming/">
<include name="**/*" />
</fileset>
</copy>
<!--Moves PDFs to the needed placement -->
<move failonerror="false"
file="${basedir}/target/docbkx/pdf/openstack-image-service-admin/os-image-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-image-service/admin/os-image-adminguide-trunk.pdf"/>
file="${basedir}/target/docbkx/pdf/openstackapi-programming.pdf"
tofile="${basedir}/target/docbkx/webhelp/api/openstack-compute/programmer/openstackapi-programming.pdf"/>
<!--Deletes leftover uneeded directories -->
<delete dir="${basedir}/target/docbkx/webhelp/openstack-image-service-admin"/>
<delete dir="${basedir}/target/docbkx/webhelp/openstackapi-programming/"/>
</postProcess>
</configuration>
</execution>
@ -133,9 +130,8 @@
<xincludeSupported>true</xincludeSupported>
<sourceDirectory>.</sourceDirectory>
<includes>
os-image-adminguide.xml
openstackapi-programming.xml
</includes>
<canonicalUrlBase>http://docs.openstack.org/trunk/openstack-image/admin/content/</canonicalUrlBase>
<profileSecurity>reviewer</profileSecurity>
<branding>openstack</branding>
</configuration>

@ -0,0 +1,37 @@
<?xml version="1.0" encoding="UTF-8"?>
<!-- (C) 2012 OpenStack LLC., All Rights Reserved -->
<application xmlns="http://wadl.dev.java.net/2009/02"
xmlns:xsdxt="http://docs.rackspacecloud.com/xsd-ext/v1.0"
xmlns:wadl="http://wadl.dev.java.net/2009/02">
<resources base="https://storage.swiftdrive.com/">
<resource id="version" path="v1">
<resource id="tenant_id" path="{tenant_id}">
<param name="tenant_id" style="template">
<doc>
<p xmlns="http://www.w3.org/1999/xhtml">
The unique identifier of the tenant or account.
</p>
</doc>
</param>
<resource id="object" path="container/object">
<method href="#createObject" />
<resource path="{container_id}">
<param name="container_id" style="template" required="true">
<doc><p xmlns="http://www.w3.org/1999/xhtml">
The unique identifier of an existing container.
</p></doc>
</param>
<method href="#getObject" />
<method href="#deleteObject" />
</resource>
</resource>
</resource>
</resource>
</resources>
</application>

@ -69,7 +69,7 @@
<xi:include href="aboutcompute.xml"/>
<xi:include href="computeinstall.xml"/>
<xi:include href="computeconfigure.xml"/>
<!--<xi:include href="../openstack-identity-service-starter/gettingstartedkeystone.xml"/>-->
<xi:include href="../common/ch_identity_mgmt.xml"/>
<xi:include href="computehypervisors.xml"/>
<xi:include href="computeautomation.xml"/>
<xi:include href="computenetworking.xml"/>

@ -182,3 +182,4 @@
</tr>
</tbody></table>
</section>
</chapter>

@ -77,7 +77,7 @@
possible, for example, to have two tenants that share a common image
store but use distinct compute servers.</para>
<para>This is a long list of entities that are involved in the process but
how does it actually work?
how does it actually work?</para>
<orderedlist>
<listitem>
<para>To access some service, users provide their credentials to
@ -96,85 +96,27 @@
<listitem>
<para>After that, Nova verifies the validity of the token in Keystone
and should create an instance from some image by the provided image
ID and plug it into some network.
ID and plug it into some network.</para>
<itemizedlist>
<listitem>At first Nova passes this token to Glance to get the
image stored somewhere in there.</listitem>
<listitem>After that, it asks Quantum to plug this new instance
<listitem><para>At first Nova passes this token to Glance to get the
image stored somewhere in there.</para></listitem>
<listitem><para>After that, it asks Quantum to plug this new instance
into a network; Quantum verifies whether the user has access to
the network in its own database and to the interface of VM by
requesting info in Nova.</listitem>
</itemizedlist>
All the way this token travels between services so that they can
requesting info in Nova.</para></listitem>
</itemizedlist>
</listitem>
<listitem><para>All the way this token travels between services so that they can
ask Keystone or each other for additional information or some
actions.</para>
</listitem>
</orderedlist>
Here is a rough diagram of this process:
<figure><mediaobject><imageobject>
actions.</para></listitem></orderedlist>
<para>Here is a rough diagram of this process:</para>
<figure><title>Keystone flowchart</title><mediaobject><imageobject>
<imagedata fileref="figures/keystone-flowchart.png" />
</imageobject></mediaobject></figure></para>
</section>
<section xml:id="example-flows">
<title>Show me some use cases</title>
<para>Below are some sample use cases for how a client and service interact with the
OpenStack Identity service, Keystone:
<orderedlist>
<listitem>
<para>Here is an example of the default authentication sequence. The flow starts with the
client knowing only their credentials and the URL to Keystone. The client
sends their credentials to Keystone and get back a default token. That default token
is then used to get a list of tenants the user has access to. The use then authenticates
again this time specifying the tenant they want to authenticate against
and they get a token that is scoped to that tenant. That token gives them the necessary
rights to perform operations on that tenant (like create a VM under that tenant in Nova).
Authenticating against the tenant also returns a service catalog
which has a list of all the endpoints the client can go to to manage resources
under that tenant. The client then picks an endpoint (in the diagram, they choose the nova endpoint)
and perform operations (like create instance to create a VM).
When the client makes that call, they pass in the token. The service, nova in this example,
checks with Keystone to see if the token is valid. Keystone responds and also returns
additional information like the user name, the roles they have, etc...
Nova them decides based on that information if the user and token have the necessary rights to perform
the operation and if they do, goes ahead and performs the operation.</para>
<figure><mediaobject><imageobject>
<imagedata fileref="figures/use_case_1.png" />
</imageobject></mediaobject>
</figure>
</listitem>
<listitem>
<para>This shows a similar sequence to the one above but with a shortcut. In this
case the client knows their tenant and goes ahead and gets a scoped token
in the first step and then calls nova right after to perform their operations.
This is a common use case since many clients may already know their tenant Id or Name.</para>
<figure><mediaobject><imageobject>
<imagedata fileref="figures/use_case_2.png" />
</imageobject></mediaobject>
</figure>
</listitem>
<listitem>
<para>This third sequence is slightly different. In this situation, the client knows the URL
for Nova, but not necessarily what authentication protocols are supported or the Keystone URL.
The flow is a lot like how browsers negotiate with web servers. They client sends an
unauthenticated call to Nova and Nova responds with a 401 listing the supported protocols in a list of
WWW-Authenticate headers. If Basic Auth is supported, this would be returned:</para>
<literallayout class="monospaced">WWW-Authenticate: Basic</literallayout>
<para>
In the case of Keystone authententiction, the returned header will say the Keystone protocol
is supported and list the Keystone URL:</para>
<literallayout class="monospaced">WWW-Authenticate: Keystone uri="https://identity.example.com:35357/"</literallayout>
<para>
The client then goes to that URL and retrieves a token and repeats the call to Nova,
but this time providing the necessary token.
</para>
<figure><mediaobject><imageobject>
<imagedata fileref="figures/use_case_3.png" />
</imageobject></mediaobject>
</figure>
</listitem>
</orderedlist>
</para>
</imageobject></mediaobject></figure>
</section>
<section xml:id="Identity-Service-Concepts-e1362">
<title>Identity Service Concepts</title>
<para> The OpenStack Identity Service, Keystone, has several key concepts
@ -279,94 +221,67 @@
</figure>
</section>
<section xml:id="installing-openstack-identity-service"><title>Installing the OpenStack Identity Service</title>
<para>You can install the Identity service from packages or from source.</para>
<para>
To install the latest version of the Identity Service (Keystone) from the Github
repositories, following the following instructions.
</para><orderedlist>
<listitem><para>
For Debian/Ubuntu, add the Keystone PPA to your sources.lst:
</para><literallayout class="monospaced">
$&gt; sudo add-apt-repository ppa:keystone-core/trunk
$&gt; sudo apt-get update
</literallayout>
</listitem>
<listitem>
<para> Install the Identity Service: </para>
<literallayout class="monospaced"> $&gt; sudo apt-get install keystone </literallayout>
</listitem>
</orderedlist>
<para> To install the latest version of the Identity Service
from the Github.com Git repositories, following the following
instructions. </para>
<orderedlist numeration="arabic">
<listitem>
<para>
Grab the source tarball from
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="https://github.com/openstack/keystone">Github</link>
</para>
</listitem>
<listitem>
<para>
Untar the source tarball:
</para>
<literallayout class="monospaced">
$&gt; tar -xzf &lt;FILE&gt;
</literallayout>
</listitem>
<listitem>
<para>
Change into the package directory and build/install:
</para>
<literallayout class="monospaced">
$&gt; cd keystone-&lt;RELEASE&gt; $&gt; sudo python setup.py install
</literallayout>
</listitem>
</orderedlist>
<para> To install the latest version of the Identity Service
from the Github repositories, see the following instructions. </para>
<para> These are for Debian/Ubuntu.</para>
<note>
<para>If you want to build the the Identity Service
documentation locally, you will also want to install the
python-sphinx package.</para>
</note>
<orderedlist numeration="arabic">
<listitem>
<para>
Install Git and build dependencies:
</para>
<literallayout class="monospaced"> $&gt; sudo apt-get install git python-eventlet python-routes python-greenlet
swift $&gt; sudo apt-get install python-argparse python-sqlalchemy python-wsgiref
python-pastedeploy </literallayout>
</listitem>
<listitem>
<para> Branch the Identity Service's trunk branch. (See
<link xmlns:xlink="http://www.w3.org/1999/xlink"
xlink:href="http://wiki.openstack.org/GerritWorkflow"
>http://wiki.openstack.org/GerritWorkflow</link> to get
the project initially setup): </para>
<literallayout class="monospaced">
$&gt; git checkout master
$&gt; git pull origin master
</literallayout>
</listitem>
<listitem>
<para> Install the Identity Service: </para>
<literallayout class="monospaced">
$&gt; sudo python setup.py install
</literallayout>
</listitem>
</orderedlist>
<para>You can install the Identity service from packages or from source. Refer to http://keystone.openstack.org for more information.</para>
</section>
<section xml:id="configuring-the-identity-service"><title>Configuring the Identity Service</title>
<para>Here are the steps to get started with authentication using Keystone, the project name for
the OpenStack Identity Service. </para>
<para>Typically a project that uses the OpenStack Identity Service
has settings in a configuration file:</para>
<para>
<itemizedlist>
<listitem>
<para>In Compute, the settings are in
etc/nova/api-paste.ini, but the Identity Service also
provides an example file in
keystone/examples/paste/nova-api-paste.ini. Restart the
nova-api service for these settings to be
configured.</para>
</listitem>
<listitem>
<para>In Image Service, the settings are in glance-api.conf and glance-registry.conf
configuration files in the examples/paste directory. Restart the glance-api service and
also ensure your environment contains OS_AUTH credentials which you can set up with tools/nova_to_os_env.sh provided by the Glance project.</para>
</listitem>
<listitem>
<para>In Object Storage, the settings are held in /etc/swift/proxy-server.conf in a
[filter:keystone] section. Use <code>swift-init main start</code> to restart Object
Storage with the new configuration. Here's an example
/etc/swift/proxy-server.conf:</para>
<literallayout class="monospaced">
[DEFAULT]
bind_port = 8888
user = &lt;user&gt;
[pipeline:main]
pipeline = catch_errors cache keystone proxy-server
[app:proxy-server]
use = egg:swift#proxy
account_autocreate = true
[filter:keystone]
use = egg:keystone#swiftauth
keystone_admin_token = 999888777666
keystone_url = http://localhost:35357/v2.0
[filter:cache]
use = egg:swift#memcache
set log_name = cache
[filter:catch_errors]
use = egg:swift#catch_errors
</literallayout>
</listitem>
</itemizedlist>
</para></section>
<section xml:id="starting-identity-service"><title>Starting the Identity Service</title>
<para>By default, configuration parameters (such as the IP and port binding
@ -393,63 +308,7 @@
keystone-manage a keystone.db sqlite database should be created
in the keystone folder.</para>
</section>
<section xml:id="configuring-the-identity-service"><title>Configuring the Identity Service</title>
<para>Here are the steps to get started with authentication using Keystone, the project name for
the OpenStack Identity Service. </para>
<para>Typically a project that uses the OpenStack Identity Service
has settings in a configuration file:</para>
<para>
<itemizedlist>
<listitem>
<para>In Compute, the settings are in
etc/nova/api-paste.ini, but the Identity Service also
provides an example file in
keystone/examples/paste/nova-api-paste.ini. Restart the
nova-api service for these settings to be
configured.</para>
</listitem>
<listitem>
<para>In Image Service, the settings are in glance-api.conf and glance-registry.conf
configuration files in the examples/paste directory. Restart the glance-api service and
also ensure your environment contains OS_AUTH credentials which you can set up with tools/nova_to_os_env.sh provided by the Glance project.</para>
</listitem>
<listitem>
<para>In Object Storage, the settings are held in /etc/swift/proxy-server.conf in a
[filter:keystone] section. Use <code>swift-init main start</code> to restart Object
Storage with the new configuration. Here's an example
/etc/swift/proxy-server.conf:</para>
<literallayout class="monospaced">
[DEFAULT]
bind_port = 8888
user = &lt;user&gt;
[pipeline:main]
pipeline = catch_errors cache keystone proxy-server
[app:proxy-server]
use = egg:swift#proxy
account_autocreate = true
[filter:keystone]
use = egg:keystone#swiftauth
keystone_admin_token = 999888777666
keystone_url = http://localhost:35357/v2.0
[filter:cache]
use = egg:swift#memcache
set log_name = cache
[filter:catch_errors]
use = egg:swift#catch_errors
</literallayout>
</listitem>
</itemizedlist>
</para></section>
<section xml:id="dependencies"><info><title>Dependencies</title></info>
<para>Once the Identity Service is installed you need to
initialize the database. You can do so with the keystone-manage
@ -526,111 +385,5 @@ use = egg:swift#catch_errors
<para>
<literallayout class="monospaced">keystone-manage endpointTemplates add SWRegion identity http://%HOST_IP%:5000/v2.0 http://%HOST_IP%:35357/v2.0 http://%HOST_IP%:5000/v2.0 1 1</literallayout>
</para> </section>
<section xml:id="curl-examples"><info><title>Curl examples</title></info>
<para>All examples assume default port usage (35357) and use the example admin account created above.</para>
<para><emphasis>Admin Initial GET</emphasis></para>
<para>Retrieves version, full API url, pdf doc link, and wadl link:</para>
<screen>$> curl http://0.0.0.0:35357</screen>
<para>to get details on a specific version:</para>
<screen>$> curl http://0.0.0.0:35357/v2.0/</screen>
<para><emphasis>Retrieve token:</emphasis></para>
<para>To retrieve the token and expiration date for a user:</para>
<screen>$> curl -d '{"auth":{"passwordCredentials":{"username": "MyAdmin", "password": "P@ssw0rd"}}}' -H "Content-type: application/json" http://localhost:5000/v2.0/tokens</screen>
<para>This will return something like:</para>
<screen>$> {"access": {"token": {"expires": "2011-08-10T17:45:22.838440", "id": "0eed0ced-4667-4221-a0b2-24c91f242b0b"}}}</screen>
<note><para>Save the “id” value as youll be using it in the calls below.</para></note>
<para><emphasis>To retrieve a list of tenants:</emphasis></para>
<para>Run:</para>
<screen>$> curl -H "X-Auth-Token:999888777666" http://localhost:35357/v2.0/tenants</screen>
<para>This will return something like:</para>
<screen>$> {"tenants": {"values": [{"enabled": 1, "id": "MyTenant", "description": null}], "links": []}}</screen>
<para><emphasis>Retrieve a list of users:</emphasis></para>
<para> Run:</para>
<screen>$> curl -H "X-Auth-Token:999888777666" http://localhost:35357/v2.0/users</screen>
<para>This will return something like:</para>
<screen>$> {"users": {"values": [{"email": null, "enabled": true, "id": "MyAdmin", "tenantId": "MyTenant"}], "links": []}}</screen>
<para><emphasis>Retrieve information about the token:</emphasis></para>
<para>Run:</para>
<screen>$> curl -H "X-Auth-Token:999888777666" http://localhost:35357/v2.0/tokens/0eed0ced-4667-4221-a0b2-24c91f242b0b</screen>
<para> This will return something like:</para>
<screen>$> {"access": {"token": {"expires": "2011-08-11T04:26:58.145171", "id": "0eed0ced-4667-4221-a0b2-24c91f242b0b"}, "user": {"username": "MyAdmin", "roles": [{"Id": "Admin", "id": 1}], "tenantId": "MyTenant"}}}</screen>
<para><emphasis> Revoking a token:</emphasis></para>
<para>Run:</para>
<screen>$> curl -X DELETE -H "X-Auth-Token:999888777666" http://localhost:3537/tokens/0eed0ced-4667-4221-a0b2-24c91f242b0b</screen>
<para><emphasis>Creating a tenant:</emphasis></para>
<para>Run:</para>
<screen> $> curl -H "X-Auth-Token:999888777666" -H "Content-type: application/json" -d '{"tenant":{"name":"MyTenant2", "description":"My 2nd Tenant", "enabled":true}}' http://localhost:35357/tenants</screen>
<para> This will return something like:</para>
<screen>$> {"tenant": {"enabled": true, "id": "372", "name": "MyTenant2", "description": "My 2nd Tenant"}}</screen>
<para><emphasis>Verifying the tenant:</emphasis></para>
<para>Run:</para>
<screen>$> curl -H "X-Auth-Token:999888777666" http://localhost:35357/v2.0/tenants/372</screen>
<para>This will return something like:</para>
<screen>$> {"tenant": {"enabled": 1, "id": "MyTenant2", "description": "My 2nd Tenant"}}</screen>
<para><emphasis>Verifying the tenant by name:</emphasis></para>
<para>Run:</para>
<screen>$> curl -H "X-Auth-Token:999888777666" http://localhost:35357/v2.0/tenants/?name-MyTenant2</screen>
<para><emphasis>Updating the tenant:</emphasis></para>
<para>Run:</para>
<screen>$> curl -X PUT -H "X-Auth-Token:999888777666" -H "Content-type: application/json" -d '{"tenant":{"description":"My NEW 2nd Tenant"}}' http://localhost:35357/v2.0/tenants/372
</screen>
<para>This will return something like:
</para>
<screen>$> {"tenant": {"enabled": true, "id": "372", "name": "MyTenant2", "description": "My NEW 2nd Tenant"}}
</screen>
<para><emphasis>Deleting the tenant:</emphasis></para>
<para>Run:</para>
<screen>$> curl -X DELETE -H "X-Auth-Token:999888777666" http://localhost:35357/v2.0/tenants/372</screen>
</section>
</chapter>

@ -50,7 +50,7 @@
<plugin>
<groupId>com.rackspace.cloud.api</groupId>
<artifactId>clouddocs-maven-plugin</artifactId>
<version>1.0.9</version>
<version>1.0.10</version>
<executions>
<execution>
<id>goal1</id>
@ -107,7 +107,7 @@
<copy
todir="${basedir}/target/docbkx/webhelp/trunk/openstack-compute/admin">
<fileset
dir="${basedir}/target/docbkx/webhelp/os-compute-adminguide/">
dir="${basedir}/target/docbkx/webhelp/bk-compute-adminguide/">
<include name="**/*" />
</fileset>
</copy>
@ -115,12 +115,12 @@
<!--Moves PDFs to the needed placement -->
<move failonerror="false"
file="${basedir}/target/docbkx/pdf/os-compute-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-compute/admin/os-compute-adminguide-trunk.pdf"/>
file="${basedir}/target/docbkx/pdf/bk-compute-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-compute/admin/bk-compute-adminguide-trunk.pdf"/>
<!--Deletes leftover uneeded directories -->
<delete dir="${basedir}/target/docbkx/webhelp/os-compute-adminguide"/>
<delete dir="${basedir}/target/docbkx/webhelp/bk-compute-adminguide"/>
</postProcess>
</configuration>
@ -131,7 +131,7 @@
<xincludeSupported>true</xincludeSupported>
<sourceDirectory>.</sourceDirectory>
<includes>
os-compute-adminguide.xml
bk-compute-adminguide.xml
</includes>
<canonicalUrlBase>http://docs.openstack.org/trunk/openstack-compute/admin/content/</canonicalUrlBase>
<profileSecurity>reviewer</profileSecurity>

Binary file not shown.

Before

(image error) Size: 45 KiB

Binary file not shown.

Before

(image error) Size: 31 KiB

Binary file not shown.

Before

(image error) Size: 42 KiB

@ -1,44 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<book xmlns="http://docbook.org/ns/docbook"
xmlns:xlink="http://www.w3.org/1999/xlink"
xmlns:xi="http://www.w3.org/2001/XInclude"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns:html="http://www.w3.org/1999/xhtml"
version="5.0"
xml:id="openstack-identity-starter-guide">
<?rax pdf.url="../os-identity-starter-guide-trunk.pdf"?>
<title>OpenStack Identity Starter Guide</title>
<info>
<author>
<personname>
<firstname/>
<surname/>
</personname>
<affiliation>
<orgname>OpenStack</orgname>
</affiliation>
</author>
<copyright>
<year>2010</year>
<year>2011</year>
<holder>OpenStack LLC</holder>
</copyright>
<releaseinfo>trunk</releaseinfo>
<productname>OpenStack Identity Service</productname>
<pubdate>2011-11-14</pubdate>
<legalnotice role="apache2">
<annotation>
<remark>Copyright details are filled in by the template.</remark>
</annotation>
</legalnotice>
<abstract>
<para>OpenStack™ Identity Service offers open source software for identity management
for cloud users and administrators. This manual provides guidance for installing,
managing, and understanding the software that runs OpenStack Identity Service.
</para>
</abstract>
</info>
<!-- Chapters are referred from the book file through these include statements. You can add additional chapters using these types of statements. -->
<xi:include href="gettingstartedkeystone.xml"/>
</book>

@ -1,148 +0,0 @@
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.openstack.docs</groupId>
<artifactId>openstack-guide</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>OpenStack Guides</name>
<!-- ################################################ -->
<!-- USE "mvn clean generate-sources" to run this POM -->
<!-- ################################################ -->
<profiles>
<profile>
<id>Rackspace Research Repositories</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<repositories>
<repository>
<id>rackspace-research</id>
<name>Rackspace Research Repository</name>
<url>http://maven.research.rackspacecloud.com/content/groups/public/</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>rackspace-research</id>
<name>Rackspace Research Repository</name>
<url>http://maven.research.rackspacecloud.com/content/groups/public/</url>
</pluginRepository>
</pluginRepositories>
</profile>
</profiles>
<build>
<resources>
<resource>
<directory>target/docbkx/pdf</directory>
<excludes>
<exclude>**/*.fo</exclude>
</excludes>
</resource>
</resources>
<plugins>
<plugin>
<groupId>com.rackspace.cloud.api</groupId>
<artifactId>clouddocs-maven-plugin</artifactId>
<version>1.0.8-SNAPSHOT</version>
<executions>
<execution>
<id>goal1</id>
<goals>
<goal>generate-pdf</goal>
</goals>
<phase>generate-sources</phase>
<configuration>
<highlightSource>false</highlightSource>
<!-- The following elements sets the autonumbering of sections in output for chapter numbers but no numbered sections-->
<sectionAutolabel>0</sectionAutolabel>
<sectionLabelIncludesComponentLabel>0</sectionLabelIncludesComponentLabel>
</configuration>
</execution>
<execution>
<id>goal2</id>
<goals>
<goal>generate-webhelp</goal>
</goals>
<phase>generate-sources</phase>
<configuration>
<!-- These parameters only apply to webhelp -->
<enableDisqus>1</enableDisqus>
<disqusShortname>os-identitydevguide</disqusShortname>
<enableGoogleAnalytics>1</enableGoogleAnalytics>
<googleAnalyticsId>UA-17511903-6</googleAnalyticsId>
<generateToc>
appendix toc,title
article/appendix nop
article toc,title
book title,figure,table,example,equation
chapter toc,title
part toc,title
preface toc,title
qandadiv toc
qandaset toc
reference toc,title
set toc,title
</generateToc>
<!-- The following elements sets the autonumbering of sections in output for chapter numbers but no numbered sections-->
<sectionAutolabel>0</sectionAutolabel>
<sectionLabelIncludesComponentLabel>0</sectionLabelIncludesComponentLabel>
<postProcess>
<!-- Copies the figures to the correct location for webhelp -->
<copy todir="${basedir}/target/docbkx/webhelp/os-identity-starter-guide/content/figures">
<fileset dir="${basedir}/figures">
<include name="**/*.png" />
</fileset>
</copy>
<!-- <copy todir="${basedir}/target/docbkx/webhelp/openstack-identity-service-starter/figures">
<fileset dir="${basedir}/figures">
<include name="**/*.jpg" />
</fileset>
</copy>-->
<!-- Copies webhelp (HTML output) to desired URL location on docs.openstack.org -->
<copy
todir="${basedir}/target/docbkx/webhelp/trunk/openstack-identity/admin">
<fileset
dir="${basedir}/target/docbkx/webhelp/os-identity-starter-guide/">
<include name="**/*" />
</fileset>
</copy>
<!--Moves PDFs to the needed placement -->
<move failonerror="false"
file="${basedir}/target/docbkx/pdf/os-identity-starter-guide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-identity/admin/os-identity-starter-guide-trunk.pdf"/>
<!--Deletes leftover uneeded directories -->
<delete dir="${basedir}/target/docbkx/webhelp/os-identity-starter-guide"/>
</postProcess>
</configuration>
</execution>
</executions>
<configuration>
<!-- These parameters apply to pdf and webhelp -->
<xincludeSupported>true</xincludeSupported>
<sourceDirectory>.</sourceDirectory>
<includes>
os-identity-starter-guide.xml
</includes>
<profileSecurity>reviewer</profileSecurity>
<branding>openstack</branding>
</configuration>
</plugin>
</plugins>
</build>
</project>

@ -1,21 +0,0 @@
<?xml version="1.0"?>
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0" xml:id="glance-architecture"><info><title>Glance Architecture</title></info><para>Glance is designed to be as adaptable as possible for various back-end storage and registry database solutions. There is a main Glance API server (the glance-api program) that serves as the communications hub between various client programs, the registry of image metadata, and the storage systems that actually contain the virtual machine image data.</para>
<para>From a birdseye perspective, one can visualize the Glance architectural model like so:</para>
<para><inlinemediaobject>
<imageobject>
<imagedata scale="80" fileref="../figures/glancearch.png"/></imageobject>
</inlinemediaobject></para>
<section><title>What is a Registry Server? </title>
<para>A registry server is any service that publishes image metadata that conforms to the
Glance Registry REST-ful API. Glance comes with a reference implementation of a registry
server called glance-registry, but this is only a reference implementation that uses a
SQL database for its metadata storage.</para></section>
<section><title>What is a Store?</title><para>A store is a Python class that inherits from glance.store.Backend and conforms to that class API for reading, writing, and deleting virtual machine image data.
Glance currently ships with stores for S3, Swift, a simple filesystem store, and a read-only HTTP(S) store.
Implementors are encouraged to create stores for other backends, including other distributed storage systems like Sheepdog or Ceph.</para></section>
</chapter>

@ -1,41 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="glance-authentication-with-keystone"><info><title>Glance Authentication With Keystone</title></info>
<para>
Glance may optionally be integrated with Keystone. Setting this up
is relatively straightforward: the Keystone distribution includes
the requisite middleware and examples of appropriately modified
<literal>glance-api.conf</literal> and
<literal>glance-registry.conf</literal> configuration files in the
<literal>examples/paste</literal> directory. Once you have installed
Keystone and edited your configuration files, newly created images
will have their `owner` attribute set to the tenant of the
authenticated users, and the `is_public` attribute will cause access
to those images for which it is `false` to be restricted to only the
owner.
</para>
<note>
<para>The exception is those images for which `owner` is set to `null`,
which may only be done by those users having the ``Admin`` role.
These images may still be accessed by the public, but will not
appear in the list of public images. This allows the Glance
Registry owner to publish images for beta testing without allowing
those images to show up in lists, potentially confusing users.</para>
</note>
<section xml:id="sharing-images-with-others"><info><title>Sharing Images With Others</title></info>
<para>
It is possible to allow a private image to be shared with one or
more alternate tenants. This is done through image
<emphasis>memberships</emphasis>, which are available via the
`members` resource of images. (For more details, see
:ref:`glanceapi`.) Essentially, a membership is an association
between an image and a tenant which has permission to access that
image. These membership associations may also have a `can_share`
attribute, which, if set to `true`, delegates the authority to
share an image to the named tenant.
</para>
</section>
</chapter>

@ -1,670 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="using-glance-programmatically-with-glances-client"><info><title>Using Glance Programmatically with Glance's Client</title></info>
<para>
While it is perfectly acceptable to issue HTTP requests directly to
Glance via its RESTful API, sometimes it is better to be able to
access and modify image resources via a client class that removes
some of the complexity and tedium of dealing with raw HTTP requests.
</para>
<para>
Glance includes a client class for just this purpose. You can
retrieve metadata about an image, change metadata about an image,
remove images, and of course retrieve an image itself via this
client class.
</para>
<para>
Below are some examples of using Glance's Client class. We assume
that there is a Glance server running at the address
`glance.example.com` on port `9292`.
</para>
<section xml:id="requesting-a-list-of-public-vm-images"><info><title>Requesting a List of Public VM Images</title></info>
<para>
We want to see a list of available virtual machine images that the
Glance server knows about.
</para>
<para>
Using Glance's Client, we can do this using the following code
</para>
<para>
..code-block:: python
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
print c.get_images()
</para>
</section>
<section xml:id="requesting-detailed-metadata-on-public-vm-images"><info><title>Requesting Detailed Metadata on Public VM Images</title></info>
<para>
We want to see more detailed information on available virtual
machine images that the Glance server knows about.
</para>
<para>
Using Glance's Client, we can do this using the following code
</para>
<para>
..code-block:: python
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
print c.get_images_detailed()
</para>
</section>
<section xml:id="filtering-images-returned-via-get_images-and-get_images_detailed"><info><title>Filtering Images Returned via <literal>get_images()</literal>
and <literal>get_images_detailed()</literal></title></info>
<para>
Both the <literal>get_images()</literal> and
<literal>get_images_detailed()</literal> methods take query
parameters that serve to filter the returned list of images.
</para>
<para>
When calling, simply pass an optional dictionary to the method
containing the filters by which you wish to limit results, with
the filter keys being one or more of the below:
</para>
<itemizedlist>
<listitem>
<para>
<literal>name: NAME</literal>
</para>
<para>
Filters images having a <literal>name</literal> attribute
matching <literal>NAME</literal>.
</para>
</listitem>
<listitem>
<para>
<literal>container_format: FORMAT</literal>
</para>
<para>
Filters images having a <literal>container_format</literal>
attribute matching <literal>FORMAT</literal>
</para>
</listitem>
<listitem>
<para>
<literal>disk_format: FORMAT</literal>
</para>
<para>
Filters images having a <literal>disk_format</literal>
attribute matching <literal>FORMAT</literal>
</para>
</listitem>
<listitem>
<para>
<literal>status: STATUS</literal>
</para>
<para>
Filters images having a <literal>status</literal> attribute
matching <literal>STATUS</literal>
</para>
</listitem>
<listitem>
<para>
<literal>size_min: BYTES</literal>
</para>
<para>
Filters images having a <literal>size</literal> attribute
greater than or equal to <literal>BYTES</literal>
</para>
</listitem>
<listitem>
<para>
<literal>size_max: BYTES</literal>
</para>
<para>
Filters images having a <literal>size</literal> attribute less
than or equal to <literal>BYTES</literal>
</para>
</listitem>
</itemizedlist>
<para>
Here's a quick example that will return all images less than or
equal to 5G in size and in the `saving` status.
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
filters = {'status': 'saving', 'size_max': (5 * 1024 * 1024 *
1024)} print c.get_images_detailed(filters=filters)
</para>
</section>
<section xml:id="sorting-images-returned-via-get_images-and-get_images_detailed"><info><title>Sorting Images Returned via <literal>get_images()</literal>
and <literal>get_images_detailed()</literal></title></info>
<para>
Two parameters are available to sort the list of images returned
by these methods.
</para>
<itemizedlist>
<listitem>
<para>
<literal>sort_key: KEY</literal>
</para>
<para>
Images can be ordered by the image attribute
<literal>KEY</literal>. Acceptable values:
<literal>id</literal>, <literal>name</literal>,
<literal>status</literal>,
<literal>container_format</literal>,
<literal>disk_format</literal>, <literal>created_at</literal>
(default) and <literal>updated_at</literal>.
</para>
</listitem>
<listitem>
<para>
<literal>sort_dir: DIR</literal>
</para>
<para>
The direction of the sort may be defined by
<literal>DIR</literal>. Accepted values:
<literal>asc</literal> for ascending or
<literal>desc</literal> (default) for descending.
</para>
</listitem>
</itemizedlist>
<para>
The following example will return a list of images sorted
alphabetically by name in ascending order.
</para>
<para>
..code-block:: python
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
print c.get_images(sort_key='name', sort_dir='asc')
</para>
</section>
<section xml:id="requesting-detailed-metadata-on-a-specific-image"><info><title>Requesting Detailed Metadata on a Specific Image</title></info>
<para>
We want to see detailed information for a specific virtual machine
image that the Glance server knows about.
</para>
<para>
We have queried the Glance server for a list of public images and
the data returned includes the `uri` field for each available
image. This `uri` field value contains the exact location needed
to get the metadata for a specific image.
</para>
<para>
Continuing the example from above, in order to get metadata about
the first public image returned, we can use the following code
</para>
<para>
..code-block:: python
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
print
c.get_image_meta("<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://glance.example.com/images/1">http://glance.example.com/images/1</link>")
</para>
</section>
<section xml:id="retrieving-a-virtual-machine-image"><info><title>Retrieving a Virtual Machine Image</title></info>
<para>
We want to retrieve that actual raw data for a specific virtual
machine image that the Glance server knows about.
</para>
<para>
We have queried the Glance server for a list of public images and
the data returned includes the `uri` field for each available
image. This `uri` field value contains the exact location needed
to get the metadata for a specific image.
</para>
<para>
Continuing the example from above, in order to get both the
metadata about the first public image returned and its image data,
we can use the following code
</para>
<para>
..code-block:: python
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
meta, image_file =
c.get_image("<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://glance.example.com/images/1">http://glance.example.com/images/1</link>")
</para>
<para>
print meta
</para>
<para>
f = open('some_local_file', 'wb') for chunk in
image_&lt;link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="file:"&gt;file:&lt;/link&gt; f.write(chunk) f.close()
</para>
<note>
<para>The return from Client.get_image() is a tuple of (`metadata`, `file`)
where `metadata` is a mapping of metadata about the image and `file` is a
generator that yields chunks of image data.</para>
</note>
</section>
<section xml:id="adding-a-new-virtual-machine-image"><info><title>Adding a New Virtual Machine Image</title></info>
<para>
We have created a new virtual machine image in some way (created a
"golden image" or snapshotted/backed up an existing
image) and we wish to do two things:
</para>
<itemizedlist>
<listitem>
<para>
Store the disk image data in Glance
</para>
</listitem>
<listitem>
<para>
Store metadata about this image in Glance
</para>
</listitem>
</itemizedlist>
<para>
We can do the above two activities in a single call to the Glance
client. Assuming, like in the examples above, that a Glance API
server is running at `glance.example.com`, we issue a call to
`glance.client.Client.add_image`.
</para>
<para>
The method signature is as follows:
</para>
<screen>
glance.client.Client.add_image(image_meta, image_data=None)
</screen>
<para>
The `image_meta` argument is a mapping containing various image
metadata. The `image_data` argument is the disk image data and is
an optional argument.
</para>
<para>
The list of metadata that `image_meta` can contain are listed
below.
</para>
<itemizedlist>
<listitem>
<para>
`name`
</para>
<para>
This key/value is required. Its value should be the name of
the image.
</para>
<para>
Note that the name of an image <emphasis>is not unique to a
Glance node</emphasis>. It would be an unrealistic expectation
of users to know all the unique names of all other user's
images.
</para>
</listitem>
<listitem>
<para>
`id`
</para>
<para>
This key/value is optional.
</para>
<para>
When present, Glance will use the supplied identifier for the
image. If the identifier already exists in that Glance node,
then a `glance.common.exception.Duplicate` will be raised.
</para>
<para>
When this key/value is <emphasis>not</emphasis> present,
Glance will generate an identifier for the image and return
this identifier in the response (see below)
</para>
</listitem>
<listitem>
<para>
`store`
</para>
<para>
This key/value is optional. Valid values are one of `file`,
`s3` or `swift`
</para>
<para>
When present, Glance will attempt to store the disk image data
in the backing store indicated by the value. If the Glance
node does not support the backing store, Glance will raise a
`glance.common.exception.BadRequest`
</para>
<para>
When not present, Glance will store the disk image data in the
backing store that is marked default. See the configuration
option `default_store` for more information.
</para>
</listitem>
<listitem>
<para>
`type`
</para>
<para>
This key/values is required. Valid values are one of `kernel`,
`machine`, `raw`, or `ramdisk`.
</para>
</listitem>
<listitem>
<para>
`size`
</para>
<para>
This key/value is optional.
</para>
<para>
When present, Glance assumes that the expected size of the
request body will be the value. If the length in bytes of the
request body <emphasis>does not match</emphasis> the value,
Glance will raise a `glance.common.exception.BadRequest`
</para>
<para>
When not present, Glance will calculate the image's size based
on the size of the request body.
</para>
</listitem>
<listitem>
<para>
`is_public`
</para>
<para>
This key/value is optional.
</para>
<para>
When present, Glance converts the value to a boolean value, so
"on, 1, true" are all true values. When true, the
image is marked as a public image, meaning that any user may
view its metadata and may read the disk image from Glance.
</para>
<para>
When not present, the image is assumed to be <emphasis>not
public</emphasis> and specific to a user.
</para>
</listitem>
<listitem>
<para>
`properties`
</para>
<para>
This key/value is optional.
</para>
<para>
When present, the value is assumed to be a mapping of
free-form key/value attributes to store with the image.
</para>
<para>
For example, if the following is the value of the `properties`
key in the `image_meta` argument:
</para>
<screen>
{'distro': 'Ubuntu 10.10'}
</screen>
<para>
Then a key/value pair of "distro"/"Ubuntu
10.10" will be stored with the image in Glance.
</para>
<para>
There is no limit on the number of free-form key/value
attributes that can be attached to the image with
`properties`. However, keep in mind that there is a 8K limit
on the size of all HTTP headers sent in a request and this
number will effectively limit the number of image properties.
</para>
<para>
If the `image_data` argument is omitted, Glance will add the
`image_meta` mapping to its registries and return the
newly-registered image metadata, including the new image's
identifier. The `status` of the image will be set to the value
`queued`.
</para>
</listitem>
</itemizedlist>
<para>
As a complete example, the following code would add a new machine
image to Glance
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<variablelist>
<varlistentry>
<term>
meta = {'name': 'Ubuntu 10.10 5G',
</term>
<listitem>
<para>
'type': 'machine', 'is_public': True, 'properties':
{'distro': 'Ubuntu 10.10'}}
</para>
</listitem>
</varlistentry>
</variablelist>
<para>
new_meta = c.add_image(meta, open('/path/to/image.tar.gz'))
</para>
<para>
print 'Stored image. Got identifier: %s' % new_meta['id']
</para>
</section>
<section xml:id="requesting-image-memberships"><info><title>Requesting Image Memberships</title></info>
<para>
We want to see a list of the other system tenants that may access
a given virtual machine image that the Glance server knows about.
</para>
<para>
Continuing from the example above, in order to get the memberships
for the image with ID 1, we can use the following code
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
members = c.get_image_members(1)
</para>
<note>
<para>The return from Client.get_image_members() is a list of dictionaries. Each
dictionary has a `member_id` key, mapping to the tenant the image is shared
with, and a `can_share` key, mapping to a boolean value that identifies
whether the member can further share the image.</para>
</note>
</section>
<section xml:id="requesting-member-images"><info><title>Requesting Member Images</title></info>
<para>
We want to see a list of the virtual machine images a given system
tenant may access.
</para>
<para>
Continuing from the example above, in order to get the images
shared with 'tenant1', we can use the following code
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
images = c.get_member_images('tenant1')
</para>
<note>
<para>The return from Client.get_member_images() is a list of dictionaries. Each
dictionary has an `image_id` key, mapping to an image shared with the member,
and a `can_share` key, mapping to a boolean value that identifies whether
the member can further share the image.</para>
</note>
</section>
<section xml:id="adding-a-member-to-an-image"><info><title>Adding a Member To an Image</title></info>
<para>
We want to authorize a tenant to access a private image.
</para>
<para>
Continuing from the example above, in order to share the image
with ID 1 with 'tenant1', and to allow 'tenant2' to not only
access the image but to also share it with other tenants, we can
use the following code
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
c.add_member(1, 'tenant1') c.add_member(1, 'tenant2', True)
</para>
<para>
..note:
</para>
<screen>
The Client.add_member() function takes one optional argument, the `can_share`
value. If one is not provided and the membership already exists, its current
`can_share` setting is left alone. If the membership does not already exist,
then the `can_share` setting will default to `False`, and the membership will
be created. In all other cases, existing memberships will be modified to use
the specified `can_share` setting, and new memberships will be created with
it. The return value of Client.add_member() is not significant.
</screen>
</section>
<section xml:id="removing-a-member-from-an-image"><info><title>Removing a Member From an Image</title></info>
<para>
We want to revoke a tenant's authorization to access a private
image.
</para>
<para>
Continuing from the example above, in order to revoke the access
of 'tenant1' to the image with ID 1, we can use the following code
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<para>
c.delete_member(1, 'tenant1')
</para>
<para>
..note:
</para>
<screen>
The return value of Client.delete_member() is not significant.
</screen>
</section>
<section xml:id="replacing-a-membership-list-for-an-image"><info><title>Replacing a Membership List For an Image</title></info>
<para>
All existing image memberships may be revoked and replaced in a
single operation.
</para>
<para>
Continuing from the example above, in order to replace the
membership list of the image with ID 1 with two entries--the first
allowing 'tenant1' to access the image, and the second allowing
'tenant2' to access and further share the image, we can use the
following code
</para>
<para>
from glance.client import Client
</para>
<para>
c = Client("glance.example.com", 9292)
</para>
<variablelist>
<varlistentry>
<term>
c.replace_members(1, {'member_id': 'tenant1', 'can_share':
False},
</term>
<listitem>
<para>
{'member_id': 'tenant2', 'can_share': True})
</para>
</listitem>
</varlistentry>
</variablelist>
<note>
<para>The first argument to Client.replace_members() is the opaque identifier of
the image; the remaining arguments are dictionaries with the keys
`member_id` (mapping to a tenant name) and `can_share`. Note that
`can_share` may be omitted, in which case any existing membership for the
specified member will be preserved through the replace operation.
</para>
<para>The return value of Client.replace_members() is not significant.</para>
</note>
</section>
</chapter>

@ -1,110 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<section xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="getting-involved"><info><title>Getting Involved</title></info>
<para>
The Glance community is a very friendly group and there are places
online to join in with the community. Feel free to ask questions.
This document points you to some of the places where you can
communicate with people.
</para>
<section xml:id="how-to-join-the-openstack-community"><info><title>How to Join the OpenStack Community</title></info>
<para>
Our community welcomes all people interested in open source cloud
computing, and there are no formal membership requirements. The
best way to join the community is to talk with others online or at
a meetup and offer contributions through Launchpad, the wiki, or
blogs. We welcome all types of contributions, from blueprint
designs to documentation to testing to deployment scripts.
</para>
</section>
<section xml:id="contributing-code"><info><title>Contributing Code</title></info>
<para>
To contribute code, sign up for a Launchpad account and sign a
contributor license agreement, available on the
<uri xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://wiki.openstack.org/CLA">http://wiki.openstack.org/CLA</uri>. Once the CLA
is signed you can contribute code through the Bazaar version
control system which is related to your Launchpad account.
</para>
</section>
<section xml:id="openstack-on-freenode-irc-network"><info><title>#openstack on Freenode IRC Network</title></info>
<para>
There is a very active chat channel at
<uri xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="irc://freenode.net/#openstack">irc://freenode.net/#openstack</uri>. This is
usually the best place to ask questions and find your way around.
IRC stands for Internet Relay Chat and it is a way to chat online
in real time. You can also ask a question and come back to the log
files to read the answer later. Logs for the #openstack IRC
channel are stored at
<uri xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://eavesdrop.openstack.org/irclogs/">http://eavesdrop.openstack.org/irclogs/</uri>.
</para>
</section>
<section xml:id="openstack-wiki"><info><title>OpenStack Wiki</title></info>
<para>
The wiki is a living source of knowledge. It is edited by the
community, and has collections of links and other sources of
information. Typically the pages are a good place to write drafts
for specs or documentation, describe a blueprint, or collaborate
with others.
</para>
<para>
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://wiki.openstack.org/">OpenStack Wiki</link>
</para>
</section>
<section xml:id="glance-on-launchpad"><info><title>Glance on Launchpad</title></info>
<para>
Launchpad is a code hosting service that hosts the Glance source
code. From Launchpad you can report bugs, ask questions, and
register blueprints (feature requests).
</para>
<itemizedlist>
<listitem>
<para>
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://wiki.openstack.org/LifeWithBzrAndLaunchpad">Learn
about how to use bzr with launchpad</link>
</para>
</listitem>
<listitem>
<para>
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://launchpad.net/glance">Launchpad Glance
Page</link>
</para>
</listitem>
</itemizedlist>
</section>
<section xml:id="openstack-blog"><info><title>OpenStack Blog</title></info>
<para>
The OpenStack blog includes a weekly newsletter that aggregates
OpenStack news from around the internet, as well as providing
inside information on upcoming events and posts from OpenStack
contributors.
</para>
<para>
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://openstack.org/blog">OpenStack Blog</link>
</para>
<para>
See also: <link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://planet.openstack.org/">Planet
OpenStack</link>, aggregating blogs about OpenStack from around
the internet into a single feed. If you'd like to contribute to
this blog aggregation with your blog posts, there are instructions
for <link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://wiki.openstack.org/AddingYourBlog">adding
your blog</link>.
</para>
</section>
<section xml:id="twitter"><info><title>Twitter</title></info>
<para>
Because all the cool kids do it:
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://twitter.com/openstack">@openstack</link>. Also
follow the
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://search.twitter.com/search?q=%23openstack">#openstack</link>
tag for relevant tweets.
</para>
</section>
</section>

@ -1,744 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="configuring-glance"><info><title>Configuring Glance</title></info>
<para>
Glance has a number of options that you can use to configure the
Glance API server, the Glance Registry server, and the various
storage backends that Glance can use to store images.
</para>
<para>
Most configuration is done via configuration files, with the Glance
API server and Glance Registry server using separate configuration
files.
</para>
<para>
When starting up a Glance server, you can specify the configuration
file to use (see <link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="controllingservers">the documentation
on controller Glance servers</link>). If you do
<emphasis role="strong">not</emphasis> specify a configuration file,
Glance will look in the following directories for a configuration
file, in order:
</para>
<itemizedlist>
<listitem>
<para>
<literal>~/.glance</literal>
</para>
</listitem>
<listitem>
<para>
<literal>~/</literal>
</para>
</listitem>
<listitem>
<para>
<literal>/etc/glance</literal>
</para>
</listitem>
<listitem>
<para>
<literal>/etc</literal>
</para>
</listitem>
</itemizedlist>
<para>
The Glance API server configuration file should be named
<literal>glance-api.conf</literal>. Similarly, the Glance Registry
server configuration file should be named
<literal>glance-registry.conf</literal>. If you installed Glance via
your operating system's package management system, it is likely that
you will have sample configuration files installed in
<literal>/etc/glance</literal>.
</para>
<para>
In addition to this documentation page, you can check the
<literal>etc/glance-api.conf</literal> and
<literal>etc/glance-registry.conf</literal> sample configuration
files distributed with Glance for example configuration files for
each server application with detailed comments on what each options
does.
</para>
<section xml:id="common-configuration-options-in-glance"><info><title>Common Configuration Options in Glance</title></info>
<para>
Glance has a few command-line options that are common to all
Glance programs:
</para>
<itemizedlist>
<listitem>
<para>
<literal>--verbose</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>False</literal>
</para>
<para>
Can be specified on the command line and in configuration files.
</para>
<para>
Turns on the INFO level in logging and prints more verbose
command-line interface printouts.
</para>
<itemizedlist>
<listitem>
<para>
<literal>--debug</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>False</literal>
</para>
<para>
Can be specified on the command line and in configuration files.
</para>
<para>
Turns on the DEBUG level in logging.
</para>
<itemizedlist>
<listitem>
<para>
<literal>--config-file=PATH</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>None</literal>
</para>
<para>
Specified on the command line only.
</para>
<para>
Takes a path to a configuration file to use when running the
program. If this CLI option is not specified, then we check to see
if the first argument is a file. If it is, then we try to use that
as the configuration file. If there is no file or there were no
arguments, we search for a configuration file in the following
order:
</para>
<itemizedlist>
<listitem>
<para>
<literal>~/.glance</literal>
</para>
</listitem>
<listitem>
<para>
<literal>~/</literal>
</para>
</listitem>
<listitem>
<para>
<literal>/etc/glance</literal>
</para>
</listitem>
<listitem>
<para>
<literal>/etc</literal>
</para>
</listitem>
</itemizedlist>
<para>
The filename that is searched for depends on the server
application name. So, if you are starting up the API server,
<literal>glance-api.conf</literal> is searched for, otherwise
<literal>glance-registry.conf</literal>.
</para>
</section>
<section xml:id="configuring-logging-in-glance"><info><title>Configuring Logging in Glance</title></info>
<para>
There are a number of configuration options in Glance that control
how Glance servers log messages.
</para>
<itemizedlist>
<listitem>
<para>
<literal>--log-config=PATH</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>None</literal>
</para>
<para>
Specified on the command line only.
</para>
<para>
Takes a path to a configuration file to use for configuring
logging.
</para>
<section xml:id="logging-options-available-only-in-configuration-files"><info><title>Logging Options Available Only in Configuration
Files</title></info>
<para>
You will want to place the different logging options in the
<emphasis role="strong">[DEFAULT]</emphasis> section in your
application configuration file. As an example, you might do the
following for the API server, in a configuration file called
<literal>etc/glance-api.conf</literal>:
</para>
<screen>
[DEFAULT]
log_file = /var/log/glance/api.log
</screen>
<itemizedlist>
<listitem>
<para>
<literal>log_file</literal>
</para>
</listitem>
</itemizedlist>
<para>
The filepath of the file to use for logging messages from
Glance's servers. If missing, the default is to output messages
to <literal>stdout</literal>, so if you are running Glance
servers in a daemon mode (using
<literal>glance-control</literal>) you should make sure that the
<literal>log_file</literal> option is set appropriately.
</para>
<itemizedlist>
<listitem>
<para>
<literal>log_dir</literal>
</para>
</listitem>
</itemizedlist>
<para>
The filepath of the directory to use for log files. If not
specified (the default) the <literal>log_file</literal> is used
as an absolute filepath.
</para>
<itemizedlist>
<listitem>
<para>
<literal>log_date_format</literal>
</para>
</listitem>
</itemizedlist>
<para>
The format string for timestamps in the log output.
</para>
<para>
Defaults to <literal>%Y-%m-%d %H:%M:%S</literal>. See the
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://docs.python.org/library/logging.html">logging
module</link> documentation for more information on setting
this format string.
</para>
</section>
</section>
<section xml:id="configuring-glance-storage-backends"><info><title>Configuring Glance Storage Backends</title></info>
<para>
There are a number of configuration options in Glance that control
how Glance stores disk images. These configuration options are
specified in the <literal>glance-api.conf</literal> config file in
the section <literal>[DEFAULT]</literal>.
</para>
<itemizedlist>
<listitem>
<para>
<literal>default_store=STORE</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>file</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
Sets the storage backend to use by default when storing images in
Glance. Available options for this option are
(<literal>file</literal>, <literal>swift</literal>, or
<literal>s3</literal>).
</para>
<section xml:id="configuring-the-filesystem-storage-backend"><info><title>Configuring the Filesystem Storage Backend</title></info>
<itemizedlist>
<listitem>
<para>
<literal>filesystem_store_datadir=PATH</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>/var/lib/glance/images/</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the filesystem storage backend.`
</para>
<para>
Sets the path where the filesystem storage backend write disk
images. Note that the filesystem storage backend will attempt to
create this directory if it does not exist. Ensure that the user
that <literal>glance-api</literal> runs under has write
permissions to this directory.
</para>
</section>
<section xml:id="configuring-the-swift-storage-backend"><info><title>Configuring the Swift Storage Backend</title></info>
<itemizedlist>
<listitem>
<para>
<literal>swift_store_auth_address=URL</literal>
</para>
</listitem>
</itemizedlist>
<para>
Required when using the Swift storage backend.
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the Swift storage backend.`
</para>
<para>
Sets the authentication URL supplied to Swift when making calls
to its storage system. For more information about the Swift
authentication system, please see the
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://swift.openstack.org/overview_auth.html">Swift
auth</link> documentation and the
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://docs.openstack.org/openstack-object-storage/admin/content/ch02s02.html">overview
of Swift authentication</link>.
</para>
<itemizedlist>
<listitem>
<para>
<literal>swift_store_user=USER</literal>
</para>
</listitem>
</itemizedlist>
<para>
Required when using the Swift storage backend.
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the Swift storage backend.`
</para>
<para>
Sets the user to authenticate against the
<literal>swift_store_auth_address</literal> with.
</para>
<itemizedlist>
<listitem>
<para>
<literal>swift_store_key=KEY</literal>
</para>
</listitem>
</itemizedlist>
<para>
Required when using the Swift storage backend.
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the Swift storage backend.`
</para>
<para>
Sets the authentication key to authenticate against the
<literal>swift_store_auth_address</literal> with for the user
<literal>swift_store_user</literal>.
</para>
<itemizedlist>
<listitem>
<para>
<literal>swift_store_container=CONTAINER</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>glance</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the Swift storage backend.`
</para>
<para>
Sets the name of the container to use for Glance images in
Swift.
</para>
<itemizedlist>
<listitem>
<para>
<literal>swift_store_create_container_on_put</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>False</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the Swift storage backend.`
</para>
<para>
If true, Glance will attempt to create the container
<literal>swift_store_container</literal> if it does not exist.
</para>
<itemizedlist>
<listitem>
<para>
<literal>swift_store_large_object_size=SIZE_IN_MB</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>5120</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the Swift storage backend.`
</para>
<para>
What size, in MB, should Glance start chunking image files and
do a large object manifest in Swift? By default, this is the
maximum object size in Swift, which is 5GB
</para>
<itemizedlist>
<listitem>
<para>
<literal>swift_store_large_object_chunk_size=SIZE_IN_MB</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>200</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the Swift storage backend.`
</para>
<para>
When doing a large object manifest, what size, in MB, should
Glance write chunks to Swift? This amount of data is written to
a temporary disk buffer during the process of chunking the image
file, and the default is 200MB
</para>
</section>
<section xml:id="configuring-the-s3-storage-backend"><info><title>Configuring the S3 Storage Backend</title></info>
<itemizedlist>
<listitem>
<para>
<literal>s3_store_host=URL</literal>
</para>
</listitem>
</itemizedlist>
<para>
Required when using the S3 storage backend.
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the S3 storage backend.`
</para>
<para>
Default: s3.amazonaws.com
</para>
<para>
Sets the main service URL supplied to S3 when making calls to
its storage system. For more information about the S3
authentication system, please see the
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://aws.amazon.com/documentation/s3/">S3
documentation</link>
</para>
<itemizedlist>
<listitem>
<para>
<literal>s3_store_access_key=ACCESS_KEY</literal>
</para>
</listitem>
</itemizedlist>
<para>
Required when using the S3 storage backend.
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the S3 storage backend.`
</para>
<para>
Sets the access key to authenticate against the
<literal>s3_store_host</literal> with.
</para>
<para>
You should set this to your 20-character Amazon AWS access key.
</para>
<itemizedlist>
<listitem>
<para>
<literal>s3_store_secret_key=SECRET_KEY</literal>
</para>
</listitem>
</itemizedlist>
<para>
Required when using the S3 storage backend.
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the S3 storage backend.`
</para>
<para>
Sets the secret key to authenticate against the
<literal>s3_store_host</literal> with for the access key
<literal>s3_store_access_key</literal>.
</para>
<para>
You should set this to your 40-character Amazon AWS secret key.
</para>
<itemizedlist>
<listitem>
<para>
<literal>s3_store_bucket=BUCKET</literal>
</para>
</listitem>
</itemizedlist>
<para>
Required when using the S3 storage backend.
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the S3 storage backend.`
</para>
<para>
Sets the name of the bucket to use for Glance images in S3.
</para>
<para>
Note that the namespace for S3 buckets is
<emphasis role="strong">global</emphasis>, and therefore you
must use a name for the bucket that is unique. It is recommended
that you use a combination of your AWS access key,
<emphasis role="strong">lowercased</emphasis> with
"glance".
</para>
<para>
For instance if your Amazon AWS access key is:
</para>
<para>
<literal>ABCDEFGHIJKLMNOPQRST</literal>
</para>
<para>
then make your bucket value be:
</para>
<para>
<literal>abcdefghijklmnopqrstglance</literal>
</para>
<itemizedlist>
<listitem>
<para>
<literal>s3_store_create_bucket_on_put</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>False</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
`This option is specific to the S3 storage backend.`
</para>
<para>
If true, Glance will attempt to create the bucket
<literal>s3_store_bucket</literal> if it does not exist.
</para>
</section>
</section>
<section xml:id="configuring-the-glance-registry"><info><title>Configuring the Glance Registry</title></info>
<para>
Glance ships with a default, reference implementation registry
server. There are a number of configuration options in Glance that
control how this registry server operates. These configuration
options are specified in the
<literal>glance-registry.conf</literal> config file in the section
<literal>[DEFAULT]</literal>.
</para>
<itemizedlist>
<listitem>
<para>
<literal>sql_connection=CONNECTION_STRING</literal>
(<literal>--sql-connection</literal> when specified on command
line)
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>None</literal>
</para>
<para>
Can be specified in configuration files. Can also be specified on
the command-line for the <literal>glance-manage</literal> program.
</para>
<para>
Sets the SQLAlchemy connection string to use when connecting to
the registry database. Please see the documentation for
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://www.sqlalchemy.org/docs/05/reference/sqlalchemy/connections.html">SQLAlchemy
connection strings</link> online.
</para>
<itemizedlist>
<listitem>
<para>
<literal>sql_timeout=SECONDS</literal> on command line)
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>3600</literal>
</para>
<para>
Can only be specified in configuration files.
</para>
<para>
Sets the number of seconds after which SQLAlchemy should reconnect
to the datastore if no activity has been made on the connection.
</para>
</section>
<section xml:id="configuring-notifications"><info><title>Configuring Notifications</title></info>
<para>
Glance can optionally generate notifications to be logged or sent
to a RabbitMQ queue. The configuration options are specified in
the <literal>glance-api.conf</literal> config file in the section
<literal>[DEFAULT]</literal>.
</para>
<itemizedlist>
<listitem>
<para>
<literal>notifier_strategy</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>noop</literal>
</para>
<para>
Sets the strategy used for notifications. Options are
<literal>logging</literal>, <literal>rabbit</literal> and
<literal>noop</literal>.
</para>
<itemizedlist>
<listitem>
<para>
<literal>rabbit_host</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>localhost</literal>
</para>
<para>
Host to connect to when using <literal>rabbit</literal> strategy.
</para>
<itemizedlist>
<listitem>
<para>
<literal>rabbit_port</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>5672</literal>
</para>
<para>
Port to connect to when using <literal>rabbit</literal> strategy.
</para>
<itemizedlist>
<listitem>
<para>
<literal>rabbit_use_ssl</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>false</literal>
</para>
<para>
Boolean to use SSL for connecting when using
<literal>rabbit</literal> strategy.
</para>
<itemizedlist>
<listitem>
<para>
<literal>rabbit_userid</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>guest</literal>
</para>
<para>
Userid to use for connection when using <literal>rabbit</literal>
strategy.
</para>
<itemizedlist>
<listitem>
<para>
<literal>rabbit_password</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>guest</literal>
</para>
<para>
Password to use for connection when using
<literal>rabbit</literal> strategy.
</para>
<itemizedlist>
<listitem>
<para>
<literal>rabbit_virtual_host</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>/</literal>
</para>
<para>
Virtual host to use for connection when using
<literal>rabbit</literal> strategy.
</para>
<itemizedlist>
<listitem>
<para>
<literal>rabbit_notification_topic</literal>
</para>
</listitem>
</itemizedlist>
<para>
Optional. Default: <literal>glance_notifications</literal>
</para>
<para>
Topic to use for connection when using <literal>rabbit</literal>
strategy.
</para>
</section>
</chapter>

@ -1,277 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="controlling-glance-servers"><info><title>Controlling Glance Servers</title></info>
<para>
This section describes the ways to start, stop, and reload Glance's
server programs.
</para>
<section xml:id="starting-a-server"><info><title>Starting a server</title></info>
<para>
There are two ways to start a Glance server (either the API server
or the reference implementation registry server that ships with
Glance):
</para>
<itemizedlist>
<listitem>
<para>
Manually calling the server program
</para>
</listitem>
<listitem>
<para>
Using the <literal>glance-control</literal> server daemon
wrapper program
</para>
</listitem>
</itemizedlist>
<para>
We recommend using the second way.
</para>
<section xml:id="manually-starting-the-server"><info><title>Manually starting the server</title></info>
<para>
The first is by directly calling the server program, passing in
command-line options and a single argument for a
<literal>paste.deploy</literal> configuration file to use when
configuring the server application.
</para>
<note>
<para>Glance ships with an ``etc/`` directory that contains sample ``paste.deploy``
configuration files that you can copy to a standard configuration directory and
adapt for your own uses. Specifically, bind_host must be set properly.</para>
</note>
<para>
If you do `not` specify a configuration file on the command
line, Glance will do its best to locate a configuration file in
one of the following directories, stopping at the first config
file it finds:
</para>
<itemizedlist>
<listitem>
<para>
<literal>$CWD</literal>
</para>
</listitem>
<listitem>
<para>
<literal>~/.glance</literal>
</para>
</listitem>
<listitem>
<para>
<literal>~/</literal>
</para>
</listitem>
<listitem>
<para>
<literal>/etc/glance</literal>
</para>
</listitem>
<listitem>
<para>
<literal>/etc</literal>
</para>
</listitem>
</itemizedlist>
<para>
The filename that is searched for depends on the server
application name. So, if you are starting up the API server,
<literal>glance-api.conf</literal> is searched for, otherwise
<literal>glance-registry.conf</literal>.
</para>
<para>
If no configuration file is found, you will see an error, like:
</para>
<screen>
$&gt; glance-api
ERROR: Unable to locate any configuration file. Cannot load application glance-api
</screen>
<para>
Here is an example showing how you can manually start the
<literal>glance-api</literal> server and
<literal>glance-registry</literal> in a shell.:
</para>
<screen>
$ sudo glance-api glance-api.conf --debug &amp;
jsuh@mc-ats1:~$ 2011-04-13 14:50:12 DEBUG [glance-api] ********************************************************************************
2011-04-13 14:50:12 DEBUG [glance-api] Configuration options gathered from config file:
2011-04-13 14:50:12 DEBUG [glance-api] /home/jsuh/glance-api.conf
2011-04-13 14:50:12 DEBUG [glance-api] ================================================
2011-04-13 14:50:12 DEBUG [glance-api] bind_host 65.114.169.29
2011-04-13 14:50:12 DEBUG [glance-api] bind_port 9292
2011-04-13 14:50:12 DEBUG [glance-api] debug True
2011-04-13 14:50:12 DEBUG [glance-api] default_store file
2011-04-13 14:50:12 DEBUG [glance-api] filesystem_store_datadir /home/jsuh/images/
2011-04-13 14:50:12 DEBUG [glance-api] registry_host 65.114.169.29
2011-04-13 14:50:12 DEBUG [glance-api] registry_port 9191
2011-04-13 14:50:12 DEBUG [glance-api] verbose False
2011-04-13 14:50:12 DEBUG [glance-api] ********************************************************************************
2011-04-13 14:50:12 DEBUG [routes.middleware] Initialized with method overriding = True, and path info altering = True
2011-04-13 14:50:12 DEBUG [eventlet.wsgi.server] (21354) wsgi starting up on http://65.114.169.29:9292/
$ sudo glance-registry glance-registry.conf &amp;
jsuh@mc-ats1:~$ 2011-04-13 14:51:16 INFO [sqlalchemy.engine.base.Engine.0x...feac] PRAGMA table_info("images")
2011-04-13 14:51:16 INFO [sqlalchemy.engine.base.Engine.0x...feac] ()
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Col ('cid', 'name', 'type', 'notnull', 'dflt_value', 'pk')
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (0, u'created_at', u'DATETIME', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (1, u'updated_at', u'DATETIME', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (2, u'deleted_at', u'DATETIME', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (3, u'deleted', u'BOOLEAN', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (4, u'id', u'INTEGER', 1, None, 1)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (5, u'name', u'VARCHAR(255)', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (6, u'disk_format', u'VARCHAR(20)', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (7, u'container_format', u'VARCHAR(20)', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (8, u'size', u'INTEGER', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (9, u'status', u'VARCHAR(30)', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (10, u'is_public', u'BOOLEAN', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (11, u'location', u'TEXT', 0, None, 0)
2011-04-13 14:51:16 INFO [sqlalchemy.engine.base.Engine.0x...feac] PRAGMA table_info("image_properties")
2011-04-13 14:51:16 INFO [sqlalchemy.engine.base.Engine.0x...feac] ()
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Col ('cid', 'name', 'type', 'notnull', 'dflt_value', 'pk')
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (0, u'created_at', u'DATETIME', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (1, u'updated_at', u'DATETIME', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (2, u'deleted_at', u'DATETIME', 0, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (3, u'deleted', u'BOOLEAN', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (4, u'id', u'INTEGER', 1, None, 1)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (5, u'image_id', u'INTEGER', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (6, u'key', u'VARCHAR(255)', 1, None, 0)
2011-04-13 14:51:16 DEBUG [sqlalchemy.engine.base.Engine.0x...feac] Row (7, u'value', u'TEXT', 0, None, 0)
$ ps aux | grep glance
root 20009 0.7 0.1 12744 9148 pts/1 S 12:47 0:00 /usr/bin/python /usr/bin/glance-api glance-api.conf --debug
root 20012 2.0 0.1 25188 13356 pts/1 S 12:47 0:00 /usr/bin/python /usr/bin/glance-registry glance-registry.conf
jsuh 20017 0.0 0.0 3368 744 pts/1 S+ 12:47 0:00 grep glance
</screen>
<para>
Simply supply the configuration file as the first argument (the
<literal>etc/glance-api.conf</literal> and
<literal>etc/glance-registry.conf</literal> sample configuration
files were used in the above example) and then any common
options you want to use (<literal>--debug</literal> was used
above to show some of the debugging output that the server shows
when starting up. Call the server program with
<literal>--help</literal> to see all available options you can
specify on the command line.)
</para>
<para>
For more information on configuring the server via the
<literal>paste.deploy</literal> configuration files, see the
section entitled Configuring Glance servers.
</para>
<para>
Note that the server `daemonizes` itself by using the standard
shell backgrounding indicator, <literal>&amp;</literal>, in the
previous example. For most use cases, we recommend using the
<literal>glance-control</literal> server daemon wrapper for
daemonizing. See below for more details on daemonization with
<literal>glance-control</literal>.
</para>
</section>
<section xml:id="using-the-glance-control-program-to-start-the-server"><info><title>Using the <literal>glance-control</literal> program to
start the server</title></info>
<para>
The second way to start up a Glance server is to use the
<literal>glance-control</literal> program.
<literal>glance-control</literal> is a wrapper script that
allows the user to start, stop, restart, and reload the other
Glance server programs in a fashion that is more conducive to
automation and scripting.
</para>
<para>
Servers started via the <literal>glance-control</literal>
program are always `daemonized`, meaning that the server program
process runs in the background.
</para>
<para>
To start a Glance server with <literal>glance-control</literal>,
simply call <literal>glance-control</literal> with a server and
the word "start", followed by any command-line options
you wish to provide. Start the server with
<literal>glance-control</literal> in the following way:
</para>
<screen>
$&gt; sudo glance-control &lt;SERVER&gt; start [CONFPATH]
</screen>
<para>
..note:
</para>
<screen>
You must use the ``sudo`` program to run ``glance-control`` currently, as the
pid files for the server programs are written to /var/run/glance/
</screen>
<para>
Here is an example that shows how to start the
<literal>glance-registry</literal> server with the
<literal>glance-control</literal> wrapper script.
</para>
<para>
::
</para>
<para>
$ sudo glance-control api start glance-api.conf Starting
glance-api with /home/jsuh/glance.conf
</para>
<para>
$ sudo glance-control registry start glance-registry.conf
Starting glance-registry with /home/jsuh/glance.conf
</para>
<para>
$ ps aux | grep glance root 20038 4.0 0.1 12728 9116 ? Ss
12:51 0:00 /usr/bin/python /usr/bin/glance-api
/home/jsuh/glance-api.conf root 20039 6.0 0.1 25188 13356 ? Ss
12:51 0:00 /usr/bin/python /usr/bin/glance-registry
/home/jsuh/glance-registry.conf jsuh 20042 0.0 0.0 3368 744
pts/1 S+ 12:51 0:00 grep glance
</para>
<para>
The same <literal>paste.deploy</literal> configuration files are
used by <literal>glance-control</literal> to start the Glance
server programs, and you can specify (as the example above
shows) a configuration file when starting the server.
</para>
</section>
</section>
<section xml:id="stopping-a-server"><info><title>Stopping a server</title></info>
<para>
If you started a Glance server manually and did not use the
<literal>&amp;</literal> backgrounding function, simply send a
terminate signal to the server process by typing
<literal>Ctrl-C</literal>
</para>
<para>
If you started the Glance server using the
<literal>glance-control</literal> program, you can use the
<literal>glance-control</literal> program to stop it. Simply do
the following:
</para>
<screen>
$&gt; sudo glance-control &lt;SERVER&gt; stop
</screen>
<para>
as this example shows:
</para>
<screen>
$&gt; sudo glance-control registry stop
Stopping glance-registry pid: 17602 signal: 15
</screen>
</section>
<section xml:id="restarting-a-server"><info><title>Restarting a server</title></info>
<para>
You can restart a server with the
<literal>glance-control</literal> program, as demonstrated here:
</para>
<screen>
$&gt; sudo glance-control registry restart etc/glance-registry.conf
Stopping glance-registry pid: 17611 signal: 15
Starting glance-registry with /home/jpipes/repos/glance/trunk/etc/glance-registry.conf
</screen>
</section>
</chapter>

Binary file not shown.

Before

(image error) Size: 40 KiB

@ -1,171 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="disk-and-container-formats"><info><title>Disk and Container Formats</title></info>
<para>
When adding an image to Glance, you are may specify what the virtual
machine image's <emphasis>disk format</emphasis> and
<emphasis>container format</emphasis> are.
</para>
<para>
This document explains exactly what these formats are.
</para>
<section xml:id="disk-format"><info><title>Disk Format</title></info>
<para>
The disk format of a virtual machine image is the format of the
underlying disk image. Virtual appliance vendors have different
formats for laying out the information contained in a virtual
machine disk image.
</para>
<para>
You can set your image's container format to one of the following:
</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="strong">raw</emphasis>
</para>
<para>
This is an unstructured disk image format
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">vhd</emphasis>
</para>
<para>
This is the VHD disk format, a common disk format used by
virtual machine monitors from VMWare, Xen, Microsoft,
VirtualBox, and others
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">vmdk</emphasis>
</para>
<para>
Another common disk format supported by many common virtual
machine monitors
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">vdi</emphasis>
</para>
<para>
A disk format supported by VirtualBox virtual machine monitor
and the QEMU emulator
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">iso</emphasis>
</para>
<para>
An archive format for the data contents of an optical disc
(e.g. CDROM).
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">qcow2</emphasis>
</para>
<para>
A disk format supported by the QEMU emulator that can expand
dynamically and supports Copy on Write
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">aki</emphasis>
</para>
<para>
This indicates what is stored in Glance is an Amazon kernel
image
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">ari</emphasis>
</para>
<para>
This indicates what is stored in Glance is an Amazon ramdisk
image
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">ami</emphasis>
</para>
<para>
This indicates what is stored in Glance is an Amazon machine
image
</para>
</listitem>
</itemizedlist>
</section>
<section xml:id="container-format"><info><title>Container Format</title></info>
<para>
The container format refers to whether the virtual machine image
is in a file format that also contains metadata about the actual
virtual machine.
</para>
<para>
There are two main types of container formats: OVF and Amazon's
AMI. In addition, a virtual machine image may have no container
format at all --basically, it's just a blob of unstructured
data...
</para>
<para>
You can set your image's container format to one of the following:
</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="strong">ovf</emphasis>
</para>
<para>
This is the OVF container format
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">bare</emphasis>
</para>
<para>
This indicates there is no container or metadata envelope for
the image
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">aki</emphasis>
</para>
<para>
This indicates what is stored in Glance is an Amazon kernel
image
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">ari</emphasis>
</para>
<para>
This indicates what is stored in Glance is an Amazon ramdisk
image
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">ami</emphasis>
</para>
<para>
This indicates what is stored in Glance is an Amazon machine
image
</para>
</listitem>
</itemizedlist>
</section>
</chapter>

@ -1,129 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="quick-guide-to-getting-started-with-glance"><info><title>Quick Guide to Getting Started with Glance</title></info>
<para>
Glance is a server that provides the following services:
</para>
<itemizedlist>
<listitem>
<para>
Ability to store and retrieve virtual machine images
</para>
</listitem>
<listitem>
<para>
Ability to store and retrieve metadata about these virtual
machine images
</para>
</listitem>
<listitem>
<para>
FUTURE: Convert a virtual machine image from one format to
another
</para>
</listitem>
<listitem>
<para>
FUTURE: Help caching proxies such as Varnish or Squid cache
machine images
</para>
</listitem>
</itemizedlist>
<para>
Communication with Glance occurs via a REST-like HTTP interface.
</para>
<para>
However, Glance includes a Client class that
makes working with Glance easy and straightforward.
</para>
<para>
As of the Cactus release, there are also command-line tools for
interacting with Glance.
</para>
<section xml:id="overview-of-glance-architecture"><info><title>Overview of Glance Architecture</title></info>
<para>
There are two main parts to Glance's architecture:
</para>
<itemizedlist>
<listitem>
<para>
Glance API server
</para>
</listitem>
<listitem>
<para>
Glance Registry server(s)
</para>
</listitem>
</itemizedlist>
<section xml:id="glance-api-server"><info><title>Glance API Server</title></info>
<para>
The API server is the main interface for Glance. It routes
requests from clients to registries of image metadata and to its
<emphasis role="strong">backend stores</emphasis>, which are the
mechanisms by which Glance actually saves incoming virtual
machine images.
</para>
<para>
The backend stores that Glance can work with are as follows:
</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="strong">Swift</emphasis>
</para>
<para>
Swift is the highly-available object storage project in
OpenStack. More information can be found about Swift
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://swift.openstack.org">here</link>.
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">Filesystem</emphasis>
</para>
<para>
The default backend that Glance uses to store virtual
machine images is the filesystem backend. This simple
backend writes image files to the local filesystem.
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">S3</emphasis>
</para>
<para>
This backend allows Glance to store virtual machine images
in Amazon's S3 service.
</para>
</listitem>
<listitem>
<para>
<emphasis role="strong">HTTP</emphasis>
</para>
<para>
Glance can read virtual machine images that are available
via HTTP somewhere on the Internet. This store is
<emphasis role="strong">readonly</emphasis>
</para>
</listitem>
</itemizedlist>
</section>
<section xml:id="glance-registry-servers"><info><title>Glance Registry Servers</title></info>
<para>
Glance registry servers are servers that conform to the Glance
Registry API. Glance ships with a reference implementation of a
registry server that complies with this API
(<literal>glance-registry</literal>).
</para>
<para>
For more details on Glance's architecture see the Architecture section. For more information on what a Glance
registry server is, see the Registries section.
</para>
</section>
</section>
</chapter>

@ -1,613 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="using-the-glance-cli-tool"><info><title>Using the Glance CLI Tool</title></info>
<para>
Glance ships with a command-line tool for querying and managing
Glance It has a fairly simple but powerful interface of the form:
</para>
<screen>
Usage: glance &lt;command&gt; [options] [args]
</screen>
<para>
Where <literal>&lt;command&gt;</literal> is one of the following:
</para>
<itemizedlist>
<listitem>
<para>
<literal>help</literal>
</para>
<para>
Show detailed help information about a specific command
</para>
</listitem>
<listitem>
<para>
<literal>add</literal>
</para>
<para>
Adds an image to Glance
</para>
</listitem>
<listitem>
<para>
<literal>update</literal>
</para>
<para>
Updates an image's stored metadata in Glance
</para>
</listitem>
<listitem>
<para>
<literal>delete</literal>
</para>
<para>
Deletes an image and its metadata from Glance
</para>
</listitem>
<listitem>
<para>
<literal>index</literal>
</para>
<para>
Lists brief information about <emphasis>public</emphasis> images
that Glance knows about
</para>
</listitem>
<listitem>
<para>
<literal>details</literal>
</para>
<para>
Lists detailed information about <emphasis>public</emphasis>
images that Glance knows about
</para>
</listitem>
<listitem>
<para>
<literal>show</literal>
</para>
<para>
Lists detailed information about a specific image
</para>
</listitem>
<listitem>
<para>
<literal>clear</literal>
</para>
<para>
Destroys all <emphasis role="strong">public</emphasis> images
and their associated metadata
</para>
</listitem>
</itemizedlist>
<para>
This document describes how to use the <literal>glance</literal>
tool for each of the above commands.
</para>
<section xml:id="the-help-command"><info><title>The <literal>help</literal> command</title></info>
<para>
Issuing the <literal>help</literal> command with a
<literal>&lt;COMMAND&gt;</literal> argument shows detailed help
about a specific command. Running <literal>glance</literal>
without any arguments shows a brief help message, like so:
</para>
<screen>
$&gt; glance
Usage: glance &lt;command&gt; [options] [args]
Commands:
help &lt;command&gt; Output help for one of the commands below
add Adds a new image to Glance
update Updates an image's metadata in Glance
delete Deletes an image from Glance
index Return brief information about images in Glance
details Return detailed information about images in
Glance
show Show detailed information about an image in
Glance
clear Removes all images and metadata from Glance
Options:
--version show program's version number and exit
-h, --help show this help message and exit
-v, --verbose Print more verbose output
-H ADDRESS, --host=ADDRESS
Address of Glance API host. Default: example.com
-p PORT, --port=PORT Port the Glance API host listens on. Default: 9292
--limit=LIMIT Page size to use while requesting image metadata
--marker=MARKER Image index after which to begin pagination
--sort_key=KEY Sort results by this image attribute.
--sort_dir=[desc|asc]
Sort results in this direction.
-f, --force Prevent select actions from requesting user
confirmation
--dry-run Don't actually execute the command, just print output
showing what WOULD happen.
</screen>
<para>
With a <literal>&lt;COMMAND&gt;</literal> argument, more
information on the command is shown, like so:
</para>
<screen>
$&gt; glance help update
glance update [options] &lt;ID&gt; &lt;field1=value1 field2=value2 ...&gt;
Updates an image's metadata in Glance. Specify metadata fields as arguments.
All field/value pairs are converted into a mapping that is passed
to Glance that represents the metadata for an image.
Field names that can be specified:
name A name for the image.
is_public If specified, interpreted as a boolean value
and sets or unsets the image's availability to the public.
disk_format Format of the disk image
container_format Format of the container
All other field names are considered to be custom properties so be careful
to spell field names correctly. :)
</screen>
</section>
<section xml:id="the-add-command"><info><title>The <literal>add</literal> command</title></info>
<para>
The <literal>add</literal> command is used to do both of the
following:
</para>
<itemizedlist>
<listitem>
<para>
Store virtual machine image data and metadata about that image
in Glance
</para>
</listitem>
<listitem>
<para>
Let Glance know about an existing virtual machine image that
may be stored somewhere else
</para>
</listitem>
</itemizedlist>
<para>
We cover both use cases below.
</para>
<section xml:id="important-information-about-uploading-images"><info><title>Important Information about Uploading Images</title></info>
<para>
Before we go over the commands for adding an image to Glance, it
is important to understand that Glance
<emphasis role="strong">does not currently inspect</emphasis>
the image files you add to it. In other words,
<emphasis role="strong">Glance only understands what you tell
it, via attributes and custom properties</emphasis>.
</para>
<para>
If the file extension of the file you upload to Glance ends in
'.vhd', Glance <emphasis role="strong">does not</emphasis> know
that the image you are uploading has a disk format of
<literal>vhd</literal>. You have to
<emphasis role="strong">tell</emphasis> Glance that the image
you are uploading has a disk format by using the
<literal>disk_format=vhd</literal> on the command line (see more
below).
</para>
<para>
By the same token, Glance does not currently allow you to upload
"multi-part" disk images at once.
<emphasis role="strong">The common operation of bundling a
kernel image and ramdisk image into a machine image is not done
automagically by Glance.</emphasis>
</para>
</section>
<section xml:id="store-virtual-machine-image-data-and-metadata"><info><title>Store virtual machine image data and metadata</title></info>
<para>
When adding an actual virtual machine image to Glance, you use
the <literal>add</literal> command. You will pass metadata about
the VM image on the command line, and you will use a standard
shell redirect to stream the image data file to
<literal>glance</literal>.
</para>
<para>
Let's walk through a simple example. Suppose we have a virtual
disk image stored on our local filesystem that we wish to
"upload" to Glance. This image is stored on our local
filesystem in <literal>/tmp/images/myimage.iso</literal>.
</para>
<para>
We'd also like to tell Glance that this image should be called
"My Image", and that the image should be public --
anyone should be able to fetch it.
</para>
<para>
Here is how we'd upload this image to Glance. Change example ip
number to your server ip number.:
</para>
<screen>
$&gt; glance add name="My Image" is_public=true &lt; /tmp/images/myimage.iso --host=65.114.169.29
</screen>
<para>
If Glance was able to successfully upload and store your VM
image data and metadata attributes, you would see something like
this:
</para>
<screen>
$&gt; glance add name="My Image" is_public=true &lt; /tmp/images/myimage.iso --host=65.114.169.29
Added new image with ID: 2
</screen>
<para>
You can use the <literal>--verbose</literal> (or
<literal>-v</literal>) command-line option to print some more
information about the metadata that was saved with the image:
</para>
<screen>
$&gt; glance --verbose add name="My Image" is_public=true &lt; /tmp/images/myimage.iso --host=65.114.169.29
Added new image with ID: 4
Returned the following metadata for the new image:
container_format =&gt; ovf
created_at =&gt; 2011-02-22T19:20:53.298556
deleted =&gt; False
deleted_at =&gt; None
disk_format =&gt; raw
id =&gt; 4
is_public =&gt; True
location =&gt; file:///tmp/images/4
name =&gt; My Image
properties =&gt; {}
size =&gt; 58520278
status =&gt; active
updated_at =&gt; None
Completed in 0.6141 sec.
</screen>
<para>
If you are unsure about what will be added, you can use the
<literal>--dry-run</literal> command-line option, which will
simply show you what <emphasis>would</emphasis> have happened:
</para>
<screen>
$&gt; glance --dry-run add name="Foo" distro="Ubuntu" is_publi=True &lt; /tmp/images/myimage.iso --host=65.114.169.29
Dry run. We would have done the following:
Add new image with metadata:
container_format =&gt; ovf
disk_format =&gt; raw
is_public =&gt; False
name =&gt; Foo
properties =&gt; {'is_publi': 'True', 'distro': 'Ubuntu'}
</screen>
<para>
This is useful for detecting problems and for seeing what the
default field values supplied by <literal>glance</literal> are.
For instance, there was a typo in the command above (the
<literal>is_public</literal> field was incorrectly spelled
<literal>is_publi</literal> which resulted in the image having
an <literal>is_publi</literal> custom property added to the
image and the <emphasis>real</emphasis>
<literal>is_public</literal> field value being `False` (the
default) and not `True`...
</para>
</section>
<section xml:id="register-a-virtual-machine-image-in-another-location"><info><title>Register a virtual machine image in another
location</title></info>
<para>
Sometimes, you already have stored the virtual machine image in
some non-Glance location -- perhaps even a location you have no
write access to -- and you want to tell Glance where this
virtual machine image is located and some metadata about it. The
<literal>add</literal> command can do this for you.
</para>
<para>
When registering an image in this way, the only difference is
that you do not use a shell redirect to stream a virtual machine
image file into Glance, but instead, you tell Glance where to
find the existing virtual machine image by setting the
<literal>location</literal> field. Below is an example of doing
this.
</para>
<para>
Let's assume that there is a virtual machine image located at
the URL
<literal>http://example.com/images/myimage.vhd</literal>. We can
register this image with Glance using the following:
</para>
<screen>
$&gt; glance --verbose add name="Some web image" disk_format=vhd container_format=ovf\
location="http://example.com/images/myimage.vhd"
Added new image with ID: 1
Returned the following metadata for the new image:
container_format =&gt; ovf
created_at =&gt; 2011-02-23T00:42:04.688890
deleted =&gt; False
deleted_at =&gt; None
disk_format =&gt; vhd
id =&gt; 1
is_public =&gt; True
location =&gt; http://example.com/images/myimage.vhd
name =&gt; Some web image
properties =&gt; {}
size =&gt; 0
status =&gt; active
updated_at =&gt; None
Completed in 0.0356 sec.
</screen>
</section>
</section>
<section xml:id="the-update-command"><info><title>The <literal>update</literal> command</title></info>
<para>
After uploading/adding a virtual machine image to Glance, it is
not possible to modify the actual virtual machine image -- images
are read-only after all --however, it <emphasis>is</emphasis>
possible to update any metadata about the image after you add it
to Glance.
</para>
<para>
The <literal>update</literal> command allows you to update the
metadata fields of a stored image. You use this command like so:
</para>
<screen>
glance update &lt;ID&gt; [field1=value1 field2=value2 ...]
</screen>
<para>
Let's say we have an image with identifier 5 that we wish to
change the is_public attribute of the image from False to True.
The following would accomplish this:
</para>
<screen>
$&gt; glance update 5 is_public=true --host=65.114.169.29
Updated image 5
</screen>
<para>
Using the <literal>--verbose</literal> flag will show you all the
updated data about the image:
</para>
<screen>
$&gt; glance --verbose update 5 is_public=true --host=65.114.169.29
Updated image 5
Updated image metadata for image 5:
URI: http://example.com/images/5
Id: 5
Public? Yes
Name: My Image
Size: 58520278
Location: file:///tmp/images/5
Disk format: raw
Container format: ovf
Completed in 0.0596 sec.
</screen>
</section>
<section xml:id="the-delete-command"><info><title>The <literal>delete</literal> command</title></info>
<para>
You can delete an image by using the <literal>delete</literal>
command, shown below:
</para>
<screen>
$&gt; glance --verbose delete 5 --host=65.114.169.29
Deleted image 5
</screen>
</section>
<section xml:id="the-index-command"><info><title>The <literal>index</literal> command</title></info>
<para>
The <literal>index</literal> command displays brief information
about the <emphasis>public</emphasis> images available in Glance,
as shown below:
</para>
<screen>
$&gt; glance index --host=65.114.169.29
ID Name Disk Format Container Format Size
---------------- ------------------------------ -------------------- -------------------- --------------
1 Ubuntu 10.10 vhd ovf 58520278
2 Ubuntu 10.04 ami ami 58520278
3 Fedora 9 vdi bare 3040
4 Vanilla Linux 2.6.22 qcow2 bare 0
</screen>
<para>
Image metadata such as 'name', 'disk_format', 'container_format'
and 'status' may be used to filter the results of an index or
details command. These commands also accept 'size_min' and
'size_max' as lower and upper bounds of the image metadata 'size.'
Any unrecognized fields are handled as custom image properties.
</para>
<para>
The 'limit' and 'marker' options are used by the index and details
commands to control pagination. The 'marker' indicates the last
record that was seen by the user. The page of results returned
will begin after the provided image ID. The 'limit' param
indicates the page size. Each request to the api will be
restricted to returning a maximum number of results. Without the
'force' option, the user will be prompted before each page of
results is fetched from the API.
</para>
<para>
Results from index and details commands may be ordered using the
'sort_key' and 'sort_dir' options. Any image attribute may be used
for 'sort_key', while only 'asc' or 'desc' are allowed for
'sort_dir'.
</para>
</section>
<section xml:id="the-details-command"><info><title>The <literal>details</literal> command</title></info>
<para>
The <literal>details</literal> command displays detailed
information about the <emphasis>public</emphasis> images available
in Glance, as shown below:
</para>
<screen>
$&gt; glance details --host=65.114.169.29
================================================================================
URI: http://example.com/images/1
Id: 1
Public? Yes
Name: Ubuntu 10.10
Status: active
Size: 58520278
Location: file:///tmp/images/1
Disk format: vhd
Container format: ovf
Property 'distro_version': 10.10
Property 'distro': Ubuntu
================================================================================
URI: http://example.com/images/2
Id: 2
Public? Yes
Name: Ubuntu 10.04
Status: active
Size: 58520278
Location: file:///tmp/images/2
Disk format: ami
Container format: ami
Property 'distro_version': 10.04
Property 'distro': Ubuntu
================================================================================
URI: http://example.com/images/3
Id: 3
Public? Yes
Name: Fedora 9
Status: active
Size: 3040
Location: file:///tmp/images/3
Disk format: vdi
Container format: bare
Property 'distro_version': 9
Property 'distro': Fedora
================================================================================
URI: http://example.com/images/4
Id: 4
Public? Yes
Name: Vanilla Linux 2.6.22
Status: active
Size: 0
Location: http://example.com/images/vanilla.iso
Disk format: qcow2
Container format: bare
================================================================================
</screen>
</section>
<section xml:id="the-show-command"><info><title>The <literal>show</literal> command</title></info>
<para>
The <literal>show</literal> command displays detailed information
about a specific image, specified with
<literal>&lt;ID&gt;</literal>, as shown below:
</para>
<screen>
$&gt; glance show 3 --host=65.114.169.29
URI: http://example.com/images/3
Id: 3
Public? Yes
Name: Fedora 9
Status: active
Size: 3040
Location: file:///tmp/images/3
Disk format: vdi
Container format: bare
Property 'distro_version': 9
Property 'distro': Fedora
</screen>
</section>
<section xml:id="the-clear-command"><info><title>The <literal>clear</literal> command</title></info>
<para>
The <literal>clear</literal> command is an administrative command
that deletes <emphasis role="strong">ALL</emphasis> images and all
image metadata. Passing the <literal>--verbose</literal> command
will print brief information about all the images that were
deleted, as shown below:
</para>
<screen>
$&gt; glance --verbose clear --host=65.114.169.29
Deleting image 1 "Some web image" ... done
Deleting image 2 "Some other web image" ... done
Completed in 0.0328 sec.
</screen>
</section>
<section xml:id="the-image-members-command"><info><title>The <literal>image-members</literal> Command</title></info>
<para>
The <literal>image-members</literal> command displays the list of
members with which a specific image, specified with
<literal>&lt;ID&gt;</literal>, is shared, as shown below:
</para>
<screen>
$&gt; glance image-members 3 --host=65.114.169.29
tenant1
tenant2 *
(*: Can share image)
</screen>
</section>
<section xml:id="the-member-images-command"><info><title>The <literal>member-images</literal> Command</title></info>
<para>
The <literal>member-images</literal> command displays the list of
images which are shared with a specific member, specified with
<literal>&lt;MEMBER&gt;</literal>, as shown below:
</para>
<screen>
$&gt; glance member-images tenant1 --host=65.114.169.29
1
2 *
(*: Can share image)
</screen>
</section>
<section xml:id="the-member-add-command"><info><title>The <literal>member-add</literal> Command</title></info>
<para>
The <literal>member-add</literal> command grants a member,
specified with <literal>&lt;MEMBER&gt;</literal>, access to a
private image, specified with <literal>&lt;ID&gt;</literal>. The
<literal>--can-share</literal> flag can be given to allow the
member to share the image, as shown below:
</para>
<screen>
$&gt; glance member-add 1 tenant1 --host=65.114.169.29
$&gt; glance member-add 1 tenant2 --can-share --host=65.114.169.29
</screen>
</section>
<section xml:id="the-member-delete-command"><info><title>The <literal>member-delete</literal> Command</title></info>
<para>
The <literal>member-delete</literal> command revokes the access of
a member, specified with <literal>&lt;MEMBER&gt;</literal>, to a
private image, specified with <literal>&lt;ID&gt;</literal>, as
shown below:
</para>
<screen>
$&gt; glance member-delete 1 tenant1
$&gt; glance member-delete 1 tenant2
</screen>
</section>
<section xml:id="the-members-replace-command"><info><title>The <literal>members-replace</literal> Command</title></info>
<para>
The <literal>members-replace</literal> command revokes all
existing memberships on a private image, specified with
<literal>&lt;ID&gt;</literal>, and replaces them with a membership
for one member, specified with <literal>&lt;MEMBER&gt;</literal>.
The <literal>--can-share</literal> flag can be given to allow the
member to share the image, as shown below:
</para>
<screen>
$&gt; glance members-replace 1 tenant1 --can-share --host=65.114.169.29
</screen>
<para>
The command is given in plural form to make it clear that all
existing memberships are affected by the command.
</para>
</section>
</chapter>

@ -1,18 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="image-identifiers"><info><title>Image Identifiers</title></info>
<para>
Images are uniquely identified by way of a URI that matches the
following signature:
</para>
<screen>
&lt;Glance Server Location&gt;/images/&lt;ID&gt;
</screen>
<para>
where `&lt;Glance Server Location&gt;` is the resource location of
the Glance service that knows about an image, and `&lt;ID&gt;` is
the image's identifier that is <emphasis>unique to that Glance
server</emphasis>.
</para>
</chapter>

@ -1,109 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="installing-glance"><info><title>Installing Glance</title></info>
<section xml:id="installing-from-packages"><info><title>Installing from packages</title></info>
<para>
To install the latest version of Glance from the Launchpad Bazaar
repositories, following the following instructions.
</para>
<section xml:id="debianubuntu"><info><title>Debian/Ubuntu</title></info>
<orderedlist numeration="arabic">
<listitem>
<para>
Add the Glance PPA to your sources.lst:
</para>
<para>
$&gt; sudo add-apt-repository ppa:glance-core/trunk $&gt;
sudo apt-get update
</para>
</listitem>
<listitem>
<para>
Install Glance:
</para>
<para>
$&gt; sudo apt-get install glance
</para>
</listitem>
</orderedlist>
</section>
</section>
<section xml:id="installing-from-source-tarballs"><info><title>Installing from source tarballs</title></info>
<para>
To install the latest version of Glance from the Launchpad Bazaar
repositories, following the following instructions.
</para>
<orderedlist numeration="arabic">
<listitem>
<para>
Grab the source tarball from
<link xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="http://launchpad.net/glance/+download">Launchpad</link>
</para>
</listitem>
<listitem>
<para>
Untar the source tarball:
</para>
<para> $&gt; tar -xzf &lt;FILE&gt; </para>
</listitem>
<listitem>
<para>
Change into the package directory and build/install:
</para>
<para>
$&gt; cd glance-&lt;RELEASE&gt; $&gt; sudo python setup.py
install
</para>
</listitem>
</orderedlist>
</section>
<section xml:id="installing-from-a-bazaar-branch"><info><title>Installing from a Bazaar Branch</title></info>
<para>
To install the latest version of Glance from the Launchpad Bazaar
repositories, following the following instructions.
</para>
<section xml:id="debianubuntu-1"><info><title>Debian/Ubuntu</title></info>
<orderedlist numeration="arabic">
<listitem>
<para>
Install Bazaar and build dependencies:
</para>
<para>
$&gt; sudo apt-get install bzr python-eventlet python-routes
python-greenlet swift $&gt; sudo apt-get install
python-argparse python-sqlalchemy python-wsgiref
python-pastedeploy
</para>
</listitem>
</orderedlist>
<note>
<para>If you want to build the Glance documentation locally, you will also want
to install the python-sphinx package.</para>
</note>
<orderedlist numeration="arabic">
<listitem>
<para>
Branch Glance's trunk branch:
</para>
<para>
$&gt; bzr branch lp:glance
</para>
</listitem>
<listitem>
<para>
Install Glance:
</para>
<para>
$&gt; sudo python setup.py install
</para>
</listitem>
</orderedlist>
</section>
</section>
</chapter>

@ -1,131 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="notifications"><info><title>Notifications</title></info>
<para>
Notifications can be generated for each upload, update or delete
image event. These can be used for auditing, troubleshooting, etc.
</para>
<section xml:id="strategies"><info><title>Strategies</title></info>
<itemizedlist>
<listitem>
<para>
logging
</para>
<para>
This strategy uses the standard Python logging infrastructure
with the notifications ending up in file specificed by the
log_file configuration directive.
</para>
</listitem>
<listitem>
<para>
rabbit
</para>
<para>
This strategy sends notifications to a rabbitmq queue. This
can then be processed by other services or applications.
</para>
</listitem>
<listitem>
<para>
noop
</para>
<para>
This strategy produces no notifications. It is the default
strategy.
</para>
</listitem>
</itemizedlist>
</section>
<section xml:id="content"><info><title>Content</title></info>
<para>
Every message contains a handful of attributes.
</para>
<itemizedlist>
<listitem>
<para>
message_id
</para>
<para>
UUID identifying the message.
</para>
</listitem>
<listitem>
<para>
publisher_id
</para>
<para>
The hostname of the glance instance that generated the
message.
</para>
</listitem>
<listitem>
<para>
event_type
</para>
<para>
Event that generated the message.
</para>
</listitem>
<listitem>
<para>
priority
</para>
<para>
One of WARN, INFO or ERROR.
</para>
</listitem>
<listitem>
<para>
timestamp
</para>
<para>
UTC timestamp of when event was generated.
</para>
</listitem>
<listitem>
<para>
payload
</para>
<para>
Data specific to the event type.
</para>
</listitem>
</itemizedlist>
</section>
<section xml:id="payload"><info><title>Payload</title></info>
<para>
WARN and ERROR events contain a text message in the payload.
</para>
<itemizedlist>
<listitem>
<para>
image.upload
</para>
<para>
For INFO events, it is the image metadata.
</para>
</listitem>
<listitem>
<para>
image.update
</para>
<para>
For INFO events, it is the image metadata.
</para>
</listitem>
<listitem>
<para>
image.delete
</para>
<para>
For INFO events, it is the image id.
</para>
</listitem>
</itemizedlist>
</section>
</chapter>

@ -1,52 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<book xmlns="http://docbook.org/ns/docbook"
xmlns:xlink="http://www.w3.org/1999/xlink"
xmlns:xi="http://www.w3.org/2001/XInclude"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns:html="http://www.w3.org/1999/xhtml"
version="5.0"
xml:id="openstack-image-service-admin-manual"
>
<?rax pdf.url="../os-image-adminguide-trunk.pdf"?>
<title>OpenStack Image Service Admin Manual</title>
<info>
<author>
<personname>
<firstname/>
<surname/>
</personname>
<affiliation>
<orgname>OpenStack</orgname>
</affiliation>
</author>
<copyright>
<year>2010</year>
<year>2011</year>
<year>2012</year>
<holder>OpenStack LLC</holder>
</copyright>
<releaseinfo>trunk</releaseinfo>
<productname>OpenStack Image Service</productname>
<pubdate>2011-11-14</pubdate>
<legalnotice role="apache2">
<annotation>
<remark>Copyright details are filled in by the template.</remark>
</annotation>
</legalnotice>
<abstract>
<para>OpenStack™ Image Service offers a service for discovering, registering, and retrieving virtual machine images. Code-named Glance, it has a RESTful API that allows querying of VM image metadata as well as retrieval of the actual image. This manual provides guidance for installing, managing, and understanding the software that runs OpenStack Image Service. </para>
</abstract>
</info>
<!-- Chapters are referred from the book file through these include statements. You can add additional chapters using these types of statements. -->
<xi:include href="gettingstarted.xml"/>
<xi:include href="installing.xml"/>
<xi:include href="identifiers.xml"/>
<xi:include href="registries.xml"/>
<xi:include href="statuses.xml"/>
<xi:include href="formats.xml"/>
<xi:include href="controllingservers.xml"/>
<xi:include href="configuring.xml"/>
<xi:include href="glance.xml"/>
<xi:include href="client.xml"/>
<xi:include href="authentication.xml"/>
</book>

@ -1,216 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="image-registries"><info><title>Image Registries</title></info>
<para>
Image metadata made available through Glance can be stored in image
`registries`. Image registries are any web service that adheres to
the Glance REST-like API for image metadata.
</para>
<para>
Glance comes with a server program
<literal>glance-registry</literal> that acts as a reference
implementation of a Glance Registry.
</para>
<para>
Please see the section about Controlling Servers for more information on starting up the
Glance registry server that ships with Glance.
</para>
<section xml:id="glance-registry-api"><info><title>Glance Registry API</title></info>
<para>
Any web service that publishes an API that conforms to the
following REST-like API specification can be used by Glance as a
registry.
</para>
<section xml:id="api-in-summary"><info><title>API in Summary</title></info>
<para>
The following is a brief description of the Glance API:
</para>
<screen>
GET /images Return brief information about public images
GET /images/detail Return detailed information about public images
GET /images/&lt;ID&gt; Return metadata about an image in HTTP headers
POST /images Register metadata about a new image
PUT /images/&lt;ID&gt; Update metadata about an existing image
DELETE /images/&lt;ID&gt; Remove an image's metadata from the registry
</screen>
</section>
</section>
<section xml:id="filtering-images-returned-via-get-images-and-get-imagesdetail"><info><title>Filtering Images Returned via <literal>GET /images</literal>
and <literal>GET /images/detail</literal></title></info>
<para>
Both the <literal>GET /images</literal> and
<literal>GET /images/detail</literal> requests take query
parameters that serve to filter the returned list of images. The
following list details these query parameters.
</para>
<itemizedlist>
<listitem>
<para>
<literal>name=NAME</literal>
</para>
<para>
Filters images having a <literal>name</literal> attribute
matching <literal>NAME</literal>.
</para>
</listitem>
<listitem>
<para>
<literal>container_format=FORMAT</literal>
</para>
<para>
Filters images having a <literal>container_format</literal>
attribute matching <literal>FORMAT</literal>
</para>
</listitem>
<listitem>
<para>
<literal>disk_format=FORMAT</literal>
</para>
<para>
Filters images having a <literal>disk_format</literal>
attribute matching <literal>FORMAT</literal>
</para>
</listitem>
<listitem>
<para>
<literal>status=STATUS</literal>
</para>
<para>
Filters images having a <literal>status</literal> attribute
matching <literal>STATUS</literal>
</para>
</listitem>
<listitem>
<para>
<literal>size_min=BYTES</literal>
</para>
<para>
Filters images having a <literal>size</literal> attribute
greater than or equal to <literal>BYTES</literal>
</para>
</listitem>
<listitem>
<para>
<literal>size_max=BYTES</literal>
</para>
<para>
Filters images having a <literal>size</literal> attribute less
than or equal to <literal>BYTES</literal>
</para>
</listitem>
</itemizedlist>
<para>
These two resources also accept sort parameters:
</para>
<itemizedlist>
<listitem>
<para>
<literal>sort_key=KEY</literal>
</para>
<para>
Results will be ordered by the specified image attribute
<literal>KEY</literal>. Accepted values include
<literal>id</literal>, <literal>name</literal>,
<literal>status</literal>, <literal>disk_format</literal>,
<literal>container_format</literal>, <literal>size</literal>,
<literal>created_at</literal> (default) and
<literal>updated_at</literal>.
</para>
</listitem>
<listitem>
<para>
<literal>sort_dir=DIR</literal>
</para>
<para>
Results will be sorted in the direction
<literal>DIR</literal>. Accepted values are
<literal>asc</literal> for ascending or
<literal>desc</literal> (default) for descending.
</para>
</listitem>
</itemizedlist>
</section>
<section xml:id="post-images"><info><title><literal>POST /images</literal></title></info>
<para>
The body of the request will be a JSON-encoded set of data about
the image to add to the registry. It will be in the following
format:
</para>
<screen>
{'image':
{'id': &lt;ID&gt;|None,
'name': &lt;NAME&gt;,
'status': &lt;STATUS&gt;,
'disk_format': &lt;DISK_FORMAT&gt;,
'container_format': &lt;CONTAINER_FORMAT&gt;,
'properties': [ ... ]
}
}
</screen>
<para>
The request shall validate the following conditions and return a
<literal>400 Bad request</literal> when any of the conditions are
not met:
</para>
<itemizedlist>
<listitem>
<para>
<literal>status</literal> must be non-empty, and must be one
of <emphasis role="strong">active</emphasis>,
<emphasis role="strong">saving</emphasis>,
<emphasis role="strong">queued</emphasis>, or
<emphasis role="strong">killed</emphasis>
</para>
</listitem>
<listitem>
<para>
<literal>disk_format</literal> must be non-empty, and must be
one of <emphasis role="strong">ari</emphasis>,
<emphasis role="strong">aki</emphasis>,
<emphasis role="strong">ami</emphasis>,
<emphasis role="strong">raw</emphasis>,
<emphasis role="strong">iso</emphasis>,
<emphasis role="strong">vhd</emphasis>,
<emphasis role="strong">vdi</emphasis>,
<emphasis role="strong">qcow2</emphasis>, or
<emphasis role="strong">vmdk</emphasis>
</para>
</listitem>
<listitem>
<para>
<literal>container_format</literal> must be non-empty, and
must be on of <emphasis role="strong">ari</emphasis>,
<emphasis role="strong">aki</emphasis>,
<emphasis role="strong">ami</emphasis>,
<emphasis role="strong">bare</emphasis>, or
<emphasis role="strong">ovf</emphasis>
</para>
</listitem>
<listitem>
<para>
If <literal>disk_format</literal> <emphasis>or</emphasis>
<literal>container_format</literal> is
<emphasis role="strong">ari</emphasis>,
<emphasis role="strong">aki</emphasis>,
<emphasis role="strong">ami</emphasis>, then
<emphasis>both</emphasis> <literal>disk_format</literal> and
<literal>container_format</literal> must be the same.
</para>
</listitem>
</itemizedlist>
<section xml:id="examples"><info><title>Examples</title></info>
<para>
..todo:: Complete examples for Glance registry API
</para>
</section>
</section>
</chapter>

@ -1,67 +0,0 @@
<?xml version="1.0"?>
<!-- Converted by db4-upgrade version 1.0 -->
<chapter xmlns="http://docbook.org/ns/docbook" version="5.0-extension RaxBook-1.0" xml:id="image-statuses"><info><title>Image Statuses</title></info>
<para>
Images in Glance can be in one the following statuses:
</para>
<itemizedlist>
<listitem>
<para>
<literal>queued</literal>
</para>
<para>
The image identifier has been reserved for an image in the
Glance registry. No image data has been uploaded to Glance.
</para>
</listitem>
<listitem>
<para>
<literal>saving</literal>
</para>
<para>
Denotes that an image's raw data is currently being uploaded to
Glance. When an image is registered with a call to `POST
/images` and there is an `x-image-meta-location` header present,
that image will never be in the `saving` status (as the image
data is already available in some other location).
</para>
</listitem>
<listitem>
<para>
<literal>active</literal>
</para>
<para>
Denotes an image that is fully available in Glance.
</para>
</listitem>
<listitem>
<para>
<literal>killed</literal>
</para>
<para>
Denotes that an error occurred during the uploading of an
image's data, and that the image is not readable.
</para>
</listitem>
<listitem>
<para>
<literal>deleted</literal>
</para>
<para>
Glance has retained the information about the image, but it is
no longer available to use. An image in this state will be
removed automatically at a later date.
</para>
</listitem>
<listitem>
<para>
<literal>pending_delete</literal>
</para>
<para>
This is similiar to `deleted`, however, Glance has not yet
removed the image data. An image in this state is recoverable.
</para>
</listitem>
</itemizedlist>
</chapter>

@ -96,7 +96,7 @@
<postProcess>
<!-- Copies the figures to the correct location for webhelp -->
<!--<copy todir="${basedir}/target/docbkx/webhelp/openstack-object-storage-admin/os-objectstorage-adminguide/figures">
<!--<copy todir="${basedir}/target/docbkx/webhelp/openstack-object-storage-admin/bk-objectstorage-adminguide/figures">
<fileset dir="${basedir}/figures">
<include name="**/*.png" />
</fileset>
@ -107,7 +107,7 @@
<copy
todir="${basedir}/target/docbkx/webhelp/trunk/openstack-object-storage/admin">
<fileset
dir="${basedir}/target/docbkx/webhelp/os-objectstorage-adminguide/">
dir="${basedir}/target/docbkx/webhelp/bk-objectstorage-adminguide/">
<include name="**/*" />
</fileset>
</copy>
@ -116,12 +116,12 @@
<!--Moves PDFs to the needed placement -->
<move failonerror="false"
file="${basedir}/target/docbkx/pdf/os-objectstorage-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-object-storage/admin/os-objectstorage-adminguide-trunk.pdf"/>
file="${basedir}/target/docbkx/pdf/bk-objectstorage-adminguide.pdf"
tofile="${basedir}/target/docbkx/webhelp/trunk/openstack-object-storage/admin/bk-objectstorage-adminguide-trunk.pdf"/>
<!--Deletes leftover uneeded directories -->
<delete dir="${basedir}/target/docbkx/webhelp/os-objectstorage-adminguide"/>
<delete dir="${basedir}/target/docbkx/webhelp/bk-objectstorage-adminguide"/>
</postProcess>
</configuration>
@ -132,7 +132,7 @@
<xincludeSupported>true</xincludeSupported>
<sourceDirectory>.</sourceDirectory>
<includes>
os-objectstorage-adminguide.xml
bk-objectstorage-adminguide.xml
</includes>
<canonicalUrlBase>http://docs.openstack.org/trunk/openstack-object-storage/admin/content/</canonicalUrlBase>
<profileSecurity>reviewer</profileSecurity>

@ -162,34 +162,24 @@
<tr>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/admin/content/">OpenStack Compute Administration Guide</a></td>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/admin/content/" class="roundedButton">Read »</a>
<!--<a href="http://docs.openstack.org/trunk/openstack-compute/admin/os-compute-adminguide-trunk.pdf"
onClick="javascript: _gaq.push(['_trackPageview', '/downloads/os-compute-adminguide-trunk-pdf']);"
class="roundedButton">PDF</a>--></td>
</td>
</tr>
<tr>
<td><a href="http://docs.openstack.org/trunk/openstack-object-storage/admin/content/">OpenStack Object Storage Administration Guide</a></td>
<td><a href="http://docs.openstack.org/trunk/openstack-object-storage/admin/content/" class="roundedButton">Read »</a>
<!--<a href="http://docs.openstack.org/trunk/openstack-object-storage/admin/os-objectstorage-adminguide-trunk.pdf"
onClick="javascript: _gaq.push(['_trackPageview', '/downloads/os-objectstorage-adminguide-trunk-pdf']);"
class="roundedButton">PDF</a>--></td>
</td>
</tr>
<tr>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/starter/content/">Ubuntu Oneiric Starter Guide - OpenStack Compute, Image, and Object Storage services</a></td>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/starter/content/" class="roundedButton">Read »</a>
<!--<a href="http://docs.openstack.org/trunk/openstack-compute/starter/openstack-starter-guide-trunk.pdf"
onClick="javascript: _gaq.push(['_trackPageview', '/downloads/openstack-starter-guide-trunk-pdf']);"
class="roundedButton">PDF</a>--></td>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/starter/content/" class="roundedButton">Read »</a></td>
</tr>
<tr>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/install/content/">OpenStack Install and Deploy Guide - Compute, Image, and Identity services plus Dashboard</a></td>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/install/content/" class="roundedButton">Read »</a>
<!--<a href="http://docs.openstack.org/diablo/openstack-compute/install/openstack-install-guide-diablo.pdf"
onClick="javascript: _gaq.push(['_trackPageview', '/downloads/openstack-install-guide-trunk-pdf']);"
class="roundedButton">PDF</a>--></td>
<td><a href="http://docs.openstack.org/trunk/openstack-compute/install/content/" class="roundedButton">Read »</a> </td>
</tr>
</table>