Skip to content

Commit

Permalink
WIP installation: add minikube installation
Browse files Browse the repository at this point in the history
* Adds local installation documentation. (addresses reanahub#4)

* Adds `minikube` specific installation option to REANA configuration
  script. (addresses reanahub#13)

Signed-off-by: Diego Rodriguez <[email protected]>
  • Loading branch information
Diego Rodriguez committed Mar 22, 2017
1 parent 245662e commit 52e6c0c
Show file tree
Hide file tree
Showing 6 changed files with 184 additions and 0 deletions.
3 changes: 3 additions & 0 deletions MANIFEST.in
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,12 @@
include COPYING
include *.rst
include *.sh
include *.txt
include pytest.ini
prune docs/_build
recursive-include docs *.py
recursive-include docs *.png
recursive-include docs *.rst
recursive-include docs *.txt
recursive-include scripts reana
recursive-include tests *.py
1 change: 1 addition & 0 deletions docs/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
:maxdepth: 2

introduction
installation
gettingstarted
architecture
components
Expand Down
66 changes: 66 additions & 0 deletions docs/installation.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
Installation
===============

Local Kubernetes installation
-----------------------------

Requirements
````````````
In order to create a local REANA cluster with Kubernetes as a backend
the following requirements must be met:

- `VirtualBox`
- `VT-x/AMD-v` virtualization must be enabled in BIOS

Quickstart
``````````

For instantiating a local REANA `minikube` based cluster you should run

.. code-block:: console
$ reana install-minikube
which will do the following:

.. literalinclude:: ../scripts/reana
:language: sh
:lines: 23-89

Once the script finishes, we should check ``kubectl get pods`` until we have an output as follows:

.. code-block:: console
$ kubectl get pods
job-controller-1390584237-0lt03 1/1 Running 0 1m
message-broker-1410199975-7c5v7 1/1 Running 0 1m
storage-admin 1/1 Running 0 1m
workflow-controller-2689978795-5kzgt 1/1 Running 0 1m
workflow-monitor-1639319062-q7v8z 1/1 Running 0 1m
yadage-alice-worker-1624764635-x8z71 1/1 Running 0 1m
yadage-atlas-worker-2909073811-t9qv3 1/1 Running 0 1m
yadage-cms-worker-209120003-js5cv 1/1 Running 0 1m
yadage-lhcb-worker-4061719987-6gpbn 1/1 Running 0 1m
zeromq-msg-proxy-1617754619-68p7v 1/1 Running 0 1m
Now we will be able to check whether the nodes are actually working. Firstly, we get the VM's ip:

.. code-block:: console
$ export MINIKUBE_IP=$(minikube ip)
Secondly, we get the current instances ports:

.. code-block:: console
$ export WORKFLOW_CONTOLLER_PORT=$(kubectl describe service workflow-controller | grep 'NodePort:' | cut -f 4 | sed -e "s@/TCP@@")
$ export WORKFLOW_MONITOR_PORT=$(kubectl describe service workflow-monitor | grep 'NodePort:' | cut -f 4 | sed -e "s@/TCP@@")
$ export JOB_CONTROLLER_PORT=$(kubectl describe service job-controller | grep 'NodePort:' | cut -f 4 | sed -e "s@/TCP@@")
And finally, we open the test URLs:

.. code-block:: console
$ open "http://$MINIKUBE_IP:$WORKFLOW_CONTROLLER_PORT"
$ open "http://$MINIKUBE_IP:$WORKFLOW_MONITOR_PORT/helloworld"
$ open "http://$MINIKUBE_IP:$JOB_CONTROLLER_PORT/jobs"
1 change: 1 addition & 0 deletions requirements-k8s.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
-e 'git+https://github.com/reanahub/reana-resources-k8s.git@master#egg=reana-resources-k8s'
112 changes: 112 additions & 0 deletions scripts/reana
Original file line number Diff line number Diff line change
@@ -0,0 +1,112 @@
#!/bin/sh
#
# This file is part of REANA.
# Copyright (C) 2017 CERN.
#
# REANA is free software; you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation; either version 2 of the License, or (at your option) any later
# version.
#
# REANA is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along with
# REANA; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
# Suite 330, Boston, MA 02111-1307, USA.
#
# In applying this license, CERN does not waive the privileges and immunities
# granted to it by virtue of its status as an Intergovernmental Organization or
# submit itself to any jurisdiction.

# TODO reana-workflow-engine-yadage is specific workflow engine, it shouldn't
# appear in a general installation file.
reana_components="reana-job-controller reana-workflow-controller reana-workflow-monitor
reana-message-broker reana-workflow-engine-yadage"


install_local_minikube () {
# Check whether the OS is supported
if ! "darwin linux" | grep -F -q -w -i "$(uname -s)"
then
echo 'Your OS is not supported.'
exit 1
else
OS="$(uname -s | tr '[:upper:]' '[:lower:]')"
fi

# Install tools `kubectl` and `minikube` if necessary
if ! command -v kubectl > /dev/null 2>&1
then
echo 'Installing latest kubectl for OSX ...'
curl -LO "https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/$OS/amd64/kubectl"
chmod +x ./kubectl
sudo mv ./kubectl /usr/local/bin/kubectl
fi

if ! command -v minikube > /dev/null 2>&1
then
echo 'Installing minikube for OSX ...'
curl -Lo minikube "https://storage.googleapis.com/minikube/releases/v0.17.1/minikube-$OS-amd64"
chmod +x minikube
sudo mv minikube /usr/local/bin/
fi

# FIXME find better way to define this dependency. `extras_require` does not support not PyPI deps and
# `dependency_links` does not seem to work.
pip install -r requirements-k8s.txt

# Start `minikube`
minikube start

# Use minikube Docker daemon, so local images will be used instead of pulling from registry
echo 'Using minikube Docker daemon ...'
eval "$(minikube docker-env)"

# Pull all REANA components images and retag for local `dev`
echo 'Pulling REANA components images ...'
for component in $reana_components
do
docker pull "reanahub/$component"
docker tag "reanahub/$component" "$component"
done

# Generate Kubernetes manifests
echo 'Building REANA configuration manifests ...'
reana-resources-k8s build-manifests

# Set current cluster secret for `reana-job-controller` component
current_cluster_secret=$(kubectl get secrets | grep 'service-account-token' | cut -d ' ' -f 1)
sed -i'' -e "s/default-token-8p260/$current_cluster_secret/" configuration-manifests/deployments/job-controller.yaml

# Deploy system
echo 'Deploying REANA on minikube ...'
kubectl create -Rf configuration-manifests

# Clean configuration manifests
rm -rf configuration-manifests
}

usage() {
echo "${0##*/} manages REANA system operations"
echo ""
echo "Usage:"
echo " install-minikube Deploys local minikube based REANA cluster"
echo " -h Help"
}

if [ "$1" != "" ]
then
case $1 in
install-minikube ) install_local_minikube
;;
clean-minikube) minikube delete
;;
-h | --help ) usage
exit
;;
esac
else
usage
fi
1 change: 1 addition & 0 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@
extras_require=extras_require,
setup_requires=setup_requires,
tests_require=tests_require,
scripts=['scripts/reana'],
classifiers=[
'Environment :: Web Environment',
'Intended Audience :: Developers',
Expand Down

0 comments on commit 52e6c0c

Please sign in to comment.