© Atos Spain S.A. 2020
Application Lifecycle Deployment Engine (ALDE) is a component of the European Project SODALITE (http://sodalite.eu), initially implemented in TANGO (http://tango-project.eu ).
ALDE is distributed under a GNU AFFERO GENERAL PUBLIC LICENSE.
ALDE is responsible for the workload scheduling and the management of the application life-cycle while it is executed. ALDE will take the application source code, packetize for different heterogeneous architectures configurations and, if possible, deploy it and manage the application execution.
More in detail each one of the previous steps:
- Compilation - ALDE is able to compile the application in different configurations depending of the selected heterogeneous architectures. The result will be a set of binaries optimal compiled for specific hardware architectures.
- Packetization - ALDE, once the application has been compiled, can packetize it. For the moment it only supports typical tar.gz files and Docker and Singularity containers.
- Deployment - ALDE is able to automatically deploy an application, launch the execution and monitor it.
This guide it is divided into two different guides, one specific to create an environment for development and another one to just run and use ALDE.
To develop for ALDE we need to install two pieces of software:
To develop ALDE it is necessary to create a Python Virtualenv (depending on your installation of Python pip3 command can be called pip):
$ pip3 install virtualenv
Collecting virtualenv
Downloading virtualenv-15.0.3-py2.py3-none-any.whl (3.5MB)
100% |████████████████████████████████| 3.5MB 398kB/s
Installing collected packages: virtualenv
Successfully installed virtualenv-15.0.3
After that, you need to create a virtualenv for you to develop:
$ virtualenv venv
Using base prefix '/Library/Frameworks/Python.framework/Versions/3.5'
New python executable in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/venv/bin/python3.5
Also creating executable in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/venv/bin/python
Installing setuptools, pip, wheel...done.
Now it time to install PyBuilder:
- First we activate the virtualenv:
$ source venv/bin/activate
- Now we install PyBuilder using Pip:
$ pip install pybuilder
Collecting pybuilder
Using cached PyBuilder-0.11.9.tar.gz
Requirement already satisfied: pip>=7.0 in ./venv/lib/python3.5/site-packages (from pybuilder)
Collecting tblib (from pybuilder)
Using cached tblib-1.3.0-py2.py3-none-any.whl
Requirement already satisfied: wheel in ./venv/lib/python3.5/site-packages (from pybuilder)
Building wheels for collected packages: pybuilder
Running setup.py bdist_wheel for pybuilder ... done
Stored in directory: /Users/davidgp/Library/Caches/pip/wheels/04/9c/b3/d2d2194e8911818abdfa1c3c47501a64602714415af28d8da8
Successfully built pybuilder
Installing collected packages: tblib, pybuilder
Successfully installed pybuilder-0.11.9 tblib-1.3.0
(venv)
Now it is possible to compile the project:
- Install first the dependencies:
$ pyb install_dependencies
PyBuilder version 0.11.9
Build started at 2016-11-11 14:55:00
------------------------------------------------------------
[INFO] Building alde version 1.0.dev0
[INFO] Executing build in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde
[INFO] Going to execute task install_dependencies
[INFO] Installing all dependencies
[INFO] Processing batch dependency 'mockito'
------------------------------------------------------------
BUILD SUCCESSFUL
------------------------------------------------------------
Build Summary
Project: alde
Version: 1.0.dev0
Base directory: /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde
Environments:
Tasks: install_dependencies [9623 ms]
Build finished at 2016-11-11 14:55:10
Build took 9 seconds (9637 ms)
- Now you can build the project (if you are using Windows, probably the coverage task is going to fail)
$ pyb
PyBuilder version 0.11.9
Build started at 2016-11-11 14:57:03
------------------------------------------------------------
[INFO] Building alde version 1.0.dev0
[INFO] Executing build in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde
[INFO] Going to execute task publish
[INFO] Installing plugin dependency coverage
[INFO] Installing plugin dependency unittest-xml-reporting
[INFO] Running unit tests
[INFO] Executing unit tests from Python modules in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/src/unittest/python
[INFO] Executed 1 unit tests
[INFO] All unit tests passed.
[INFO] Building distribution in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/target/dist/alde-1.0.dev0
[INFO] Copying scripts to /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/target/dist/alde-1.0.dev0/scripts
[INFO] Writing setup.py as /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/target/dist/alde-1.0.dev0/setup.py
[INFO] Collecting coverage information
[WARN] coverage_branch_threshold_warn is 0 and branch coverage will not be checked
[WARN] coverage_branch_partial_threshold_warn is 0 and partial branch coverage will not be checked
[INFO] Running unit tests
[INFO] Executing unit tests from Python modules in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/src/unittest/python
[INFO] Executed 1 unit tests
[INFO] All unit tests passed.
[WARN] Module '__init__' was not imported by the covered tests
[INFO] Overall coverage is 94%
[INFO] Overall coverage branch coverage is 100%
[INFO] Overall coverage partial branch coverage is 100%
[INFO] Building binary distribution in /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/target/dist/alde-1.0.dev0
------------------------------------------------------------
BUILD SUCCESSFUL
------------------------------------------------------------
Build Summary
Project: alde
Version: 1.0.dev0
Base directory: /Users/davidgp/Documents/trabajo/TANGO/repositorios/alde
Environments:
Tasks: prepare [2407 ms] compile_sources [0 ms] run_unit_tests [40 ms] package [3 ms] run_integration_tests [0 ms] verify [134 ms] publish [616 ms]
Build finished at 2016-11-11 14:57:06
Build took 3 seconds (3219 ms)
Done!
Now, remember, each time you need to start to develop, initalize the virtualenv:
$ source venv/bin/activate
- Install Singularity - View doc
In this case, we are going to detail how to run the application directly using Python. It is possible to run it behind a proxy or webserver, to do so, please, check this guides.
ALDE employs a SQLite database server that needs to be configured. That configuration can be done editing the file alde_configuration.ini that contains these two variables:
[DEFAULT]
SQL_LITE_URL = sqlite:////tmp/test.db
PORT = 5000
To install it, it is necessary to execute the following command:
python setup.py install
To launch the service we need to execute:
$ python app.py
2017-07-18 09:16:02,812 root INFO Loading configuration
[]
<Section: DEFAULT>
2017-07-18 09:16:02,813 root INFO Starting ALDE
/Users/davidgp/Documents/trabajo/TANGO/repositorios/alde/venv/lib/python3.6/site-packages/flask_sqlalchemy/__init__.py:839: FSADeprecationWarning: SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future. Set it to True or False to suppress this warning.
'SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and '
2017-07-18 09:16:02,937 apscheduler.scheduler INFO Adding job tentatively -- it will be properly scheduled when the scheduler starts
2017-07-18 09:16:02,937 apscheduler.scheduler INFO Adding job tentatively -- it will be properly scheduled when the scheduler starts
2017-07-18 09:16:02,938 apscheduler.scheduler INFO Adding job tentatively -- it will be properly scheduled when the scheduler starts
2017-07-18 09:16:02,940 apscheduler.scheduler INFO Added job "check_nodes_in_db_for_on_line_testbeds" to job store "default"
2017-07-18 09:16:02,940 apscheduler.scheduler INFO Added job "update_node_info" to job store "default"
2017-07-18 09:16:02,940 apscheduler.scheduler INFO Added job "update_cpu_node_info" to job store "default"
2017-07-18 09:16:02,940 apscheduler.scheduler INFO Scheduler started
2017-07-18 09:16:02,986 werkzeug INFO * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
After it we could verify it works just by execution the following (in this example we are using Curl but you could use another REST/http client):
$ curl localhost:5000/api/v1/testbeds
{
"num_results": 0,
"objects": [],
"page": 1,
"total_pages": 0
}
Although a CLI client is planned, for the moment ALDE offers a REST interface.
The class diagram can help understanding the ALDE usage.
The rest api is fully documented here: ( https://applicationlifecycledeploymentengine.docs.apiary.io/ )
Listing all applications available:
curl http://localhost:5000/api/v1/applications
Creating an application
$ curl -X POST -H'Content-type: application/json' http://127.0.0.1:5000/api/v1/applications -d'{ "name": "my_app" }'
{
"executables": [],
"execution_scripts": [],
"id": 1,
"name": "my_app"
}
Uploading zip file with the source code of the application. Pay attention to the two variables: compilation_type and compilation_script
$ curl -X POST -F "[email protected]" http://localhost:5000/api/v1/upload/1?compilation_type=SINGULARITY:PM\&compilation_script=./build.sh
file upload for app with id: 1
Seeing the status of the compilation (executable section):
$ curl http://localhost:5000/api/v1/applications/1
{
"executables": [
{
"application_id": 1,
"compilation_script": "compilation.sh",
"compilation_type": "singularity:pm",
"executable_file": null,
"id": 1,
"source_code_file": "f5a8e16b-6c36-4092-97cb-6081374d9b29.zip",
"status": "NOT_COMPILED"
}
],
"execution_scripts": [],
"id": 1,
"name": "my_app"
}
curl localhost:5000/api/v1/testbeds -X POST -H'Content-type: application/json' -d'{ "name": "slurm_testbed", "on_line": true, "category": "SLURM", "protocol": "SSH", "endpoint": "[email protected]"}'