Django-orchestra ships with a set of management commands for automating some of the installation steps.
These commands are meant to be run within a clean Debian-like distribution, you should be specially careful while following this guide on a customized system.
Django-orchestra can be manually installed on any Linux system, however it is strongly recommended to chose the reference platform for your deployment (Debian 8.0 Jessie and Python 3.4).
-
Create a system user for running Orchestra
adduser orchestra # not required but it will be very handy sudo adduser orchestra sudo su - orchestra
-
Install django-orchestra's source code
sudo apt-get install python3-pip sudo pip3 install http://git.io/django-orchestra-dev
-
Install requirements
sudo orchestra-admin install_requirements
-
Create a new project
cd ~orchestra orchestra-admin startproject <project_name> # e.g. panel cd <project_name>
-
Create and configure a Postgres database
sudo apt-get install python3-psycopg2 postgresql sudo python3 manage.py setuppostgres --db_password <password> python3 manage.py migrate
-
Configure periodic execution of tasks (choose one)
-
Use cron (recommended)
python3 manage.py setupcronbeat python3 manage.py syncperiodictasks
-
Use celeryd
sudo apt-get install rabbitmq-server sudo python3 manage.py setupcelery --username orchestra
-
-
(Optional) Configure logging
sudo python3 manage.py setuplog
-
Configure the web server:
python3 manage.py collectstatic --noinput sudo apt-get install nginx-full uwsgi uwsgi-plugin-python3 sudo python3 manage.py setupnginx --user orchestra
-
See the Django deployment checklist
python3 manage.py check --deploy
-
Start all services:
sudo python3 manage.py startservices
To upgrade your Orchestra installation to the last release you can use upgradeorchestra
management command. Before rolling the upgrade it is strongly recommended to check the release notes.
sudo python3 manage.py upgradeorchestra
Current in development version (master branch) can be installed by
sudo python3 manage.py upgradeorchestra dev
Additionally the following command can be used in order to determine the currently installed version:
python3 manage.py orchestraversion
-
Generate a passwordless ssh key for orchestra user ssh-keygen
-
Copy this key to all servers orchestra will manage, including itself is neccessary ssh-copy-id root@