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.