From 539d15a7326affad4cc688bf92e3a85d868125e0 Mon Sep 17 00:00:00 2001 From: Sharat Sharma Date: Mon, 3 Oct 2016 16:32:07 +0530 Subject: [PATCH] Minor changes in the installation guides This patch adds small changes to the install guides. Change-Id: Ic7b0c0313d1f2d561a38be46b55df87ab5bb7609 Partially-Implements: blueprint mistral-doc --- doc/source/guides/installation_guide.rst | 104 ++++++++++++++-------- doc/source/guides/mistralclient_guide.rst | 35 +++++--- 2 files changed, 89 insertions(+), 50 deletions(-) diff --git a/doc/source/guides/installation_guide.rst b/doc/source/guides/installation_guide.rst index 0317133bb..c38f61c1b 100644 --- a/doc/source/guides/installation_guide.rst +++ b/doc/source/guides/installation_guide.rst @@ -4,7 +4,10 @@ Mistral Installation Guide Prerequisites ------------- -It is necessary to install some specific system libs for installing Mistral. They can be installed on most popular operating system using their package manager (for Ubuntu - *apt*, for Fedora, CentOS - *yum*, for Mac OS - *brew* or *macports*). +It is necessary to install some specific system libs for installing Mistral. +They can be installed on most popular operating system using their package +manager (for Ubuntu - *apt*, for Fedora - *dnf*, CentOS - *yum*, for Mac OS - +*brew* or *macports*). The list of needed packages is shown below: 1. **python-dev** @@ -18,9 +21,12 @@ The list of needed packages is shown below: In case of Ubuntu, just run:: - apt-get install python-dev python-setuptools python-pip libffi-dev libxslt1-dev libxml2-dev libyaml-dev libssl-dev + $ apt-get install python-dev python-setuptools python-pip libffi-dev libxslt1-dev \ + libxml2-dev libyaml-dev libssl-dev -**NOTE:** **Mistral can be used without authentication at all or it can work with OpenStack.** In case of OpenStack, it works **only on Keystone v3**, make sure **Keystone v3** is installed. +**NOTE:** **Mistral can be used without authentication at all or it can work +with OpenStack.** In case of OpenStack, it works **only on Keystone v3**, make +sure **Keystone v3** is installed. Installation ------------ @@ -29,113 +35,139 @@ Installation First of all, clone the repo and go to the repo directory:: - git clone https://github.com/openstack/mistral.git - cd mistral + $ git clone https://github.com/openstack/mistral.git + $ cd mistral Generate config:: - tox -egenconfig + $ tox -egenconfig -Configure Mistral as needed. The configuration file is located in ``etc/mistral.conf``. For details see :doc:`Mistral Configuration Guide ` +Configure Mistral as needed. The configuration file is located in ``etc/mistral.conf``. +For details see :doc:`Mistral Configuration Guide ` **Virtualenv installation**:: - tox + $ tox -This will install necessary virtual environments and run all the project tests. Installing virtual environments may take significant time (~10-15 mins). +This will install necessary virtual environments and run all the project tests. +Installing virtual environments may take significant time (~10-15 mins). **Local installation**:: - pip install -e . + $ pip install -e . or:: - pip install -r requirements.txt - python setup.py install + $ pip install -r requirements.txt + $ python setup.py install -**NOTE**: Differences *pip install -e* and *setup.py install*. **pip install -e** works very similarly to **setup.py install** or the EasyInstall tool, except that it doesn’t actually install anything. Instead, it creates a special .egg-link file in the deployment directory, that links to your project’s source code. +**NOTE**: Differences *pip install -e* and *setup.py install*. **pip install -e** +works very similarly to **setup.py install** or the EasyInstall tool, except +that it doesn’t actually install anything. Instead, it creates a special +.egg-link file in the deployment directory, that links to your project’s +source code. Before the first run -------------------- -After installation you will see **mistral-server** and **mistral-db-manage** commands in your environment, either in system or virtual environment. +After installation you will see **mistral-server** and **mistral-db-manage** commands +in your environment, either in system or virtual environment. -**NOTE**: In case of using **virtualenv**, all Mistral related commands available via **tox -evenv --**. For example, *mistral-server* is available via *tox -evenv -- mistral-server*. +**NOTE**: In case of using **virtualenv**, all Mistral related commands available via +**tox -evenv --**. For example, *mistral-server* is available via +*tox -evenv -- mistral-server*. **mistral-db-manage** command can be used for migrations. For updating the database to the latest revision type:: - mistral-db-manage --config-file upgrade head + $ mistral-db-manage --config-file upgrade head -Before starting Mistral server, run *mistral-db-manage populate* command. It prepares the DB, creates in it with all standard actions and standard workflows which Mistral provides for all Mistral users. -:: +Before starting Mistral server, run *mistral-db-manage populate* command. +It prepares the DB, creates in it with all standard actions and standard +workflows which Mistral provides for all Mistral users.:: - mistral-db-manage --config-file populate + $ mistral-db-manage --config-file populate For more detailed information about *mistral-db-manage* script please see :doc:`Mistral Upgrade Guide `. -**NOTE**: For users who want a dry run with **SQLite** database backend(not used in production), *mistral-db-manage* is not recommended for database initialization because of `SQLite limitations `_. Please use sync_db script described below instead for database initialization. +**NOTE**: For users who want a dry run with **SQLite** database backend(not +used in production), *mistral-db-manage* is not recommended for database +initialization because of `SQLite limitations `_. +Please use sync_db script described below instead for database initialization. **If you use virtualenv**:: - tools/sync_db.sh --config-file + $ tools/sync_db.sh --config-file **Or run sync_db directly**:: - python tools/sync_db.py --config-file + $ python tools/sync_db.py --config-file Running Mistral API server -------------------------- To run Mistral API server perform the following command in a shell:: - mistral-server --server api --config-file + $ mistral-server --server api --config-file Running Mistral Engines ----------------------- To run Mistral Engine perform the following command in a shell:: - mistral-server --server engine --config-file + $ mistral-server --server engine --config-file Running Mistral Task Executors ------------------------------ To run Mistral Task Executor instance perform the following command in a shell:: - mistral-server --server executor --config-file + $ mistral-server --server executor --config-file -Note that at least one Engine instance and one Executor instance should be running so that workflow tasks are processed by Mistral. +Note that at least one Engine instance and one Executor instance should be +running so that workflow tasks are processed by Mistral. Running Multiple Mistral Servers Under the Same Process ------------------------------------------------------- -To run more than one server (API, Engine, or Task Executor) on the same process, perform the following command in a shell:: +To run more than one server (API, Engine, or Task Executor) on the same process, +perform the following command in a shell:: - mistral-server --server api,engine --config-file + $ mistral-server --server api,engine --config-file -The --server command line option can be a comma delimited list. The valid options are "all" (by default if not specified) or any combination of "api", "engine", and "executor". It's important to note that the "fake" transport for the rpc_backend defined in the config file should only be used if "all" the Mistral servers are launched on the same process. Otherwise, messages do not get delivered if the Mistral servers are launched on different processes because the "fake" transport is using an in process queue. +The --server command line option can be a comma delimited list. The valid +options are "all" (by default if not specified) or any combination of "api", +"engine", and "executor". It's important to note that the "fake" transport for +the rpc_backend defined in the config file should only be used if "all" the +Mistral servers are launched on the same process. Otherwise, messages do not +get delivered if the Mistral servers are launched on different processes +because the "fake" transport is using an in process queue. Mistral And Docker ------------------ Please first refer `installation steps for docker `_. -To build the image from the mistral source, change directory to the root directory of the Mistral git repository and run:: +To build the image from the mistral source, change directory to the root +directory of the Mistral git repository and run:: - docker build -t . + $ docker build -t . In case you want pre-built image, you can download it from `openstack tarballs source `_. To load this image to docker registry, please run following command:: - docker load -i '' + $ docker load -i '' -The Mistral Docker image is configured to store the database in the user's home directory. For persistence of these data, you may want to keep this directory outside of the container. This may be done by the following steps:: +The Mistral Docker image is configured to store the database in the user's home +directory. For persistence of these data, you may want to keep this directory +outside of the container. This may be done by the following steps:: - sudo mkdir '' - docker run -it -v '':/home/mistral + $ sudo mkdir '' + $ docker run -it -v '':/home/mistral More about docker: https://www.docker.com/ -**NOTE:** This docker image uses **SQLite** database. So, it cannot be used for production environment. If you want to use this for production environment, then put customized mistral.conf to ''. +**NOTE:** This docker image uses **SQLite** database. So, it cannot be used for +production environment. If you want to use this for production environment, +then put customized mistral.conf to ''. Mistral Client Installation --------------------------- diff --git a/doc/source/guides/mistralclient_guide.rst b/doc/source/guides/mistralclient_guide.rst index 0044c5d1e..ce1a99a3b 100644 --- a/doc/source/guides/mistralclient_guide.rst +++ b/doc/source/guides/mistralclient_guide.rst @@ -4,40 +4,44 @@ Mistral Client / CLI Guide Mistralclient installation -------------------------- -To install ``python-mistralclient``, it is required to have ``pip`` (in most cases). Make sure that ``pip`` is installed. Then type:: +To install ``python-mistralclient``, it is required to have ``pip`` +(in most cases). Make sure that ``pip`` is installed. Then type:: - pip install python-mistralclient + $ pip install python-mistralclient -Or, if it is needed to install ``python-mistralclient`` from master branch, type:: +Or, if it is needed to install ``python-mistralclient`` from master branch, +type:: - pip install git+https://github.com/openstack/python-mistralclient.git + $ pip install git+https://github.com/openstack/python-mistralclient.git -After ``python-mistralclient`` is installed you will see command ``mistral`` in your environment. +After ``python-mistralclient`` is installed you will see command ``mistral`` +in your environment. Configure authentication against Keystone ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -If Keystone is used for authentication in Mistral, then the environment should have auth variables:: +If Keystone is used for authentication in Mistral, then the environment should +have auth variables:: - export OS_AUTH_URL=http://:5000/v2.0 - export OS_USERNAME=admin - export OS_TENANT_NAME=tenant - export OS_PASSWORD=secret - export OS_MISTRAL_URL=http://:8989/v2 (optional, by default URL=http://localhost:8989/v2) + $ export OS_AUTH_URL=http://:5000/v2.0 + $ export OS_USERNAME=admin + $ export OS_TENANT_NAME=tenant + $ export OS_PASSWORD=secret + $ export OS_MISTRAL_URL=http://:8989/v2 (optional, by default URL=http://localhost:8989/v2) and in the case when you are authenticating against keystone over https:: - export OS_CACERT= + $ export OS_CACERT= .. note:: In client, we can use both Keystone auth versions - v2.0 and v3. But server supports only v3. You can see the list of available commands by typing:: - mistral --help + $ mistral --help To make sure Mistral client works, type:: - mistral workbook-list + $ mistral workbook-list Mistralclient commands ---------------------- @@ -694,3 +698,6 @@ Services API usage: mistral service-list List all services. + +.. seealso:: + `Workflow service command-line client `_.