CloudLaunch is a ReSTful, extensible Django app for discovering and launching applications on cloud, container, or local infrastructure. A live version is available at https://launch.usegalaxy.org/.
CloudLaunch can be extended with your own plug-ins which can provide custom launch logic for arbitrary custom applications. Visit the live site to see currently available applications in the Catalog. CloudLaunch is also tightly integrated with CloudBridge, which makes CloudLaunch natively multi-cloud.
CloudLaunch has a web and commandline front-end. The Web UI is maintained in the CloudLaunch-UI repository. The commandline client is maintained in the cloudlaunch-cli repository.
This is an all-new version of CloudLaunch that replaces the original BioCloudCentral launcher. Code for that version is available in the BioCloudCentral branch.
- Install the cloudlaunch django server
$ pip install cloudlaunch-server
Once installed, You can run django admin commands as follows:
$ cloudlaunch-server django
- Copy
cloudlaunchserver/settings_local.py.sample
tocloudlaunchserver/settings_local.py
and make any desired configuration changes. Make sure to change the value forFERNET_KEYS
variable because it is used to encrypt sensitive database fields. - Prepare the database with:
$ cloudlaunch-server django migrate
$ cloudlaunch-server django createsuperuser
$ cloudlaunch-server django runserver
- Start the development server and celery task queue (along with a Redis server as the message broker), each process in its own tab.
$ python manage.py runserver
$ redis-server & celery -A cloudlaunchserver worker -l info --beat
- Visit http://127.0.0.1:8000/admin/ to define your application and infrastructure properties.
- Visit http://127.0.0.1:8000/api/v1/ to explore the API.
You will probably also want to install the UI for the server. The default UI is available at https://github.com/galaxyproject/cloudlaunch-ui.
CloudLaunch is based on Python 3.6 and although it may work on older Python versions, 3.6 is the only supported version. Use of Conda or virtualenv is also highly advised.
- Checkout cloudlaunch and create environment
$ conda create --name cl python=3.6
$ conda activate cl
$ git clone -b dev https://github.com/galaxyproject/cloudlaunch.git
$ cd cloudlaunch
$ python setup.py develop
$ cd django-cloudlaunch
- Copy
cloudlaunchserver/settings_local.py.sample
tocloudlaunchserver/settings_local.py
and make any desired configuration changes. - Run the migrations and create a superuser:
$ python manage.py migrate
$ python manage.py createsuperuser
- Start the web server and Celery
$ python manage.py runserver
$ redis-server & celery -A cloudlaunchserver worker -l info --beat