Skip to content

Latest commit

 

History

History
123 lines (80 loc) · 3.15 KB

README.md

File metadata and controls

123 lines (80 loc) · 3.15 KB

superman-web

A web interface to the Superman tools.

Quick start

1: Install dependencies

While it’s theoretically possible to install dependencies using pip install -r requirements.txt, we had problems with this on an Ubuntu 24.04 server with Python 3.12.

You will need root privileges to install an older version of Python and some support libraries. We also elected to install a few modules this way so they could automatically be kept up to date.

sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt update
sudo apt install python3.9-full python3.9-dev
sudo apt install cython3 libfreetype-dev libomp-dev pkg-config
sudo apt install python3-dask python3-yaml python3-setuptools python3-tornado
chown www-data:www-data /opt

The remainder of the instructions below should be executed as the www-data user:

python3.9 -m venv --system-site-packages /opt/devas-venv
source /opt/devas-venv/bin/activate
pip install h5py pandas PyWavelets scikit-learn

Clone the Superman repo into /opt/superman.

cd /opt/superman
pip install .

Clone this repo into /opt/devas-web and it should be ready to configure and run.

2: Configure

An example config file is provided at config-template.yml. Copy this to config.yml and edit as needed. Any values left commented-out or not included will use reasonable defaults.

In the same way, copy datasets-template.yml to datasets.yml and update the listings to match your local datasets.

3: Add datasets

Datasets are the basic unit of data in the superman server. Add one by modifying the datasets.yml configuration file, optionally adding a loader function to the custom_datasets.py module. Relative paths are evaluated starting from the current working directory of the process running superman_server.py, typically the root of this repository.

Running the service

Using systemctl

We have provided a Systemd service definition for automatically starting and stopping the service. It can be symlinked to make using it easy:

sudo ln -s /opt/devas-web/devas.service /etc/systemd/system/
sudo systemctl daemon-reload

It provides the usual start/stop/restart functionality; don’t forget to

sudo systemctl enable devas.service

to have start on server reboot.

Manual control

To start (or restart) the server in the background for typical use, run:

./restart_server.sh

Use the option --dry-run to check what would happen without interfering with any currently running server.

Or simply run the server directly, and handle the details yourself:

python superman_server.py

To stop the server without restarting it, use:

./restart_server.sh --kill

Other notes

Original documentation claimed that we could set up to run tests:

pip install pytest mock coverage

If you want to verify that everything is working as intended, try running the test suite (located in the test/ directory):

python -m pytest

To generate a nice code coverage report:

coverage run --source backend -m pytest
coverage html