Sahara Installation Guide
=========================
We recommend to install Sahara in a way that will keep your system in a
consistent state. We suggest the following options:
* Install via `Fuel `_
* Install via `RDO Havana+ `_
* Install into virtual environment
To install with Fuel
--------------------
1. Start by following the `Quickstart
`_ to install and setup
OpenStack.
2. Enable Sahara service during installation.
To install with RDO
-------------------
1. Start by following the `Quickstart
`_ to install and setup
OpenStack.
2. Install the sahara-api service:
.. sourcecode:: console
$ yum install openstack-sahara
..
3. Configure the sahara-api service to your liking. The configuration
file is located in ``/etc/sahara/sahara.conf``. For details see
:doc:`Sahara Configuration Guide `
4. Create database schema:
.. sourcecode:: console
$ sahara-db-manage --config-file /etc/sahara/sahara.conf upgrade head
..
5. Start the sahara-api service:
.. sourcecode:: console
$ service openstack-sahara-api start
..
To install into a virtual environment
-------------------------------------
1. First you need to install a number of packages with your
OS package manager. The list of packages depends on the OS you use.
For Ubuntu run:
.. sourcecode:: console
$ sudo apt-get install python-setuptools python-virtualenv python-dev
..
For Fedora:
.. sourcecode:: console
$ sudo yum install gcc python-setuptools python-virtualenv python-devel
..
For CentOS:
.. sourcecode:: console
$ sudo yum install gcc python-setuptools python-devel
$ sudo easy_install pip
$ sudo pip install virtualenv
2. Setup virtual environment for Sahara:
.. sourcecode:: console
$ virtualenv sahara-venv
..
This will install python virtual environment into ``sahara-venv`` directory
in your current working directory. This command does not require super
user privileges and could be executed in any directory current user has
write permission.
3. You can install the latest Sahara release from pypi:
.. sourcecode:: console
$ sahara-venv/bin/pip install sahara
..
Or you can get Sahara archive from ``_ and install it using pip:
.. sourcecode:: console
$ sahara-venv/bin/pip install 'http://tarballs.openstack.org/sahara/sahara-master.tar.gz'
..
Note that sahara-master.tar.gz contains the latest changes and might not be stable at the moment.
We recommend browsing ``_ and selecting the latest stable release.
4. After installation you should create configuration file from a sample
config located in ``sahara-venv/share/sahara/sahara.conf.sample-basic``:
.. sourcecode:: console
$ mkdir sahara-venv/etc
$ cp sahara-venv/share/sahara/sahara.conf.sample-basic sahara-venv/etc/sahara.conf
..
Make the necessary changes in ``sahara-venv/etc/sahara.conf``.
For details see :doc:`Sahara Configuration Guide `
5. If you use Sahara with MySQL database, then for storing big Job Binaries
in Sahara Internal Database you must configure size of max allowed packet.
Edit ``my.cnf`` and change parameter:
.. sourcecode:: ini
...
[mysqld]
...
max_allowed_packet = 256M
..
and restart mysql server.
6. Create database schema:
.. sourcecode:: console
$ sahara-venv/bin/sahara-db-manage --config-file sahara-venv/etc/sahara.conf upgrade head
..
7. To start Sahara call:
.. sourcecode:: console
$ sahara-venv/bin/sahara-api --config-file sahara-venv/etc/sahara.conf
..
Notes:
------
One of the :doc:`Sahara Features `, Anti-Affinity, requires a Nova adjustment.
See :ref:`Enabling Anti-Affinity ` for details. But that is purely optional.
Make sure that your operating system is not blocking Sahara port (default: 8386).
You may need to configure iptables in CentOS and some other operating systems.
To get the list of all possible options run:
.. sourcecode:: console
$ sahara-venv/bin/python sahara-venv/bin/sahara-api --help
..
Further consider reading :doc:`overview` for general Sahara concepts and
:doc:`plugins` for specific plugin features/requirements.