2012-03-21 11:25:06 -05:00
|
|
|
DevStack is a set of scripts and utilities to quickly deploy an OpenStack cloud.
|
2011-09-30 11:34:43 -07:00
|
|
|
|
|
|
|
# Goals
|
|
|
|
|
2014-05-14 12:36:29 +01:00
|
|
|
* To quickly build dev OpenStack environments in a clean Ubuntu or Fedora
|
|
|
|
environment
|
|
|
|
* To describe working configurations of OpenStack (which code branches
|
|
|
|
work together? what do config files look like for those branches?)
|
|
|
|
* To make it easier for developers to dive into OpenStack so that they can
|
|
|
|
productively contribute without having to understand every part of the
|
|
|
|
system at once
|
2011-09-30 11:34:43 -07:00
|
|
|
* To make it easy to prototype cross-project features
|
2014-05-14 12:36:29 +01:00
|
|
|
* To provide an environment for the OpenStack CI testing on every commit
|
|
|
|
to the projects
|
2011-09-12 16:15:11 -07:00
|
|
|
|
2015-09-26 18:05:34 +05:30
|
|
|
Read more at http://docs.openstack.org/developer/devstack
|
2011-10-13 10:36:00 -07:00
|
|
|
|
2013-10-17 12:03:55 -05:00
|
|
|
IMPORTANT: Be sure to carefully read `stack.sh` and any other scripts you
|
|
|
|
execute before you run them, as they install software and will alter your
|
|
|
|
networking configuration. We strongly recommend that you run `stack.sh`
|
|
|
|
in a clean and disposable vm when you are first getting started.
|
2013-08-04 19:53:19 -05:00
|
|
|
|
2011-11-23 12:50:46 -08:00
|
|
|
# Versions
|
2011-09-30 09:24:00 -07:00
|
|
|
|
2013-10-17 12:03:55 -05:00
|
|
|
The DevStack master branch generally points to trunk versions of OpenStack
|
|
|
|
components. For older, stable versions, look for branches named
|
|
|
|
stable/[release] in the DevStack repo. For example, you can do the
|
2015-02-18 11:24:31 -08:00
|
|
|
following to create a juno OpenStack cloud:
|
2011-11-23 12:50:46 -08:00
|
|
|
|
2015-02-18 11:24:31 -08:00
|
|
|
git checkout stable/juno
|
2011-09-30 09:24:00 -07:00
|
|
|
./stack.sh
|
|
|
|
|
2013-10-17 12:03:55 -05:00
|
|
|
You can also pick specific OpenStack project releases by setting the appropriate
|
|
|
|
`*_BRANCH` variables in the ``localrc`` section of `local.conf` (look in
|
|
|
|
`stackrc` for the default set). Usually just before a release there will be
|
|
|
|
milestone-proposed branches that need to be tested::
|
2012-02-03 22:56:38 -06:00
|
|
|
|
2013-11-07 22:36:10 +11:00
|
|
|
GLANCE_REPO=git://git.openstack.org/openstack/glance.git
|
2012-03-21 11:25:06 -05:00
|
|
|
GLANCE_BRANCH=milestone-proposed
|
2012-02-03 22:56:38 -06:00
|
|
|
|
|
|
|
# Start A Dev Cloud
|
|
|
|
|
2013-10-17 12:03:55 -05:00
|
|
|
Installing in a dedicated disposable VM is safer than installing on your
|
|
|
|
dev machine! Plus you can pick one of the supported Linux distros for
|
|
|
|
your VM. To start a dev cloud run the following NOT AS ROOT (see
|
|
|
|
**DevStack Execution Environment** below for more on user accounts):
|
2011-09-30 11:34:43 -07:00
|
|
|
|
2011-11-23 12:50:46 -08:00
|
|
|
./stack.sh
|
2011-09-30 11:34:43 -07:00
|
|
|
|
2014-05-14 12:36:29 +01:00
|
|
|
When the script finishes executing, you should be able to access OpenStack
|
|
|
|
endpoints, like so:
|
2011-09-30 11:34:43 -07:00
|
|
|
|
2011-11-23 12:50:46 -08:00
|
|
|
* Horizon: http://myhost/
|
|
|
|
* Keystone: http://myhost:5000/v2.0/
|
2011-09-30 11:34:43 -07:00
|
|
|
|
2014-05-14 12:36:29 +01:00
|
|
|
We also provide an environment file that you can use to interact with your
|
|
|
|
cloud via CLI:
|
2011-09-12 16:15:11 -07:00
|
|
|
|
2013-10-17 12:03:55 -05:00
|
|
|
# source openrc file to load your environment with OpenStack CLI creds
|
2011-11-23 12:50:46 -08:00
|
|
|
. openrc
|
|
|
|
# list instances
|
|
|
|
nova list
|
2012-03-08 00:33:54 -06:00
|
|
|
|
|
|
|
If the EC2 API is your cup-o-tea, you can create credentials and use euca2ools:
|
|
|
|
|
|
|
|
# source eucarc to generate EC2 credentials and set up the environment
|
|
|
|
. eucarc
|
2011-11-23 12:50:46 -08:00
|
|
|
# list instances using ec2 api
|
|
|
|
euca-describe-instances
|
2011-09-12 19:29:56 -07:00
|
|
|
|
2013-10-04 12:35:24 -05:00
|
|
|
# DevStack Execution Environment
|
|
|
|
|
2014-05-14 12:36:29 +01:00
|
|
|
DevStack runs rampant over the system it runs on, installing things and
|
|
|
|
uninstalling other things. Running this on a system you care about is a recipe
|
|
|
|
for disappointment, or worse. Alas, we're all in the virtualization business
|
|
|
|
here, so run it in a VM. And take advantage of the snapshot capabilities
|
|
|
|
of your hypervisor of choice to reduce testing cycle times. You might even save
|
|
|
|
enough time to write one more feature before the next feature freeze...
|
2013-10-04 12:35:24 -05:00
|
|
|
|
2015-08-10 13:53:40 +10:00
|
|
|
``stack.sh`` needs to have root access for a lot of tasks, but uses
|
|
|
|
``sudo`` for all of those tasks. However, it needs to be not-root for
|
|
|
|
most of its work and for all of the OpenStack services. ``stack.sh``
|
|
|
|
specifically does not run if started as root.
|
2013-10-04 12:35:24 -05:00
|
|
|
|
2015-08-10 13:53:40 +10:00
|
|
|
DevStack will not automatically create the user, but provides a helper
|
|
|
|
script in ``tools/create-stack-user.sh``. Run that (as root!) or just
|
|
|
|
check it out to see what DevStack's expectations are for the account
|
|
|
|
it runs under. Many people simply use their usual login (the default
|
|
|
|
'ubuntu' login on a UEC image for example).
|
2013-10-17 12:03:55 -05:00
|
|
|
|
2015-08-10 13:53:40 +10:00
|
|
|
# Customizing
|
2013-10-17 12:03:55 -05:00
|
|
|
|
2015-08-10 13:53:40 +10:00
|
|
|
DevStack can be extensively configured via the configuration file
|
|
|
|
`local.conf`. It is likely that you will need to provide and modify
|
|
|
|
this file if you want anything other than the most basic setup. Start
|
|
|
|
by reading the [configuration guide](doc/source/configuration.rst) for
|
2015-09-26 18:05:34 +05:30
|
|
|
details of the configuration file and the many available options.
|