lightserv is a flask application that enables users to submit requests to acquire light sheet microscope images (and derivative data products) of their biological samples at the Princeton Neuroscience Institute. Users can view the status of their current and past requests and view their acquired data in Neuroglancer at each step in the image processing pipeline.
The processing pipeline used by the app is brainpipe. This pipeline is run using Princeton's on-premises high performance computers, namely spock.
The application uses datajoint to connect to a MariaDB database for storing metadata about the requests during the various steps in the pipeline.
The application also provides visualizations of the users' light sheet data using the BRAIN CoGS fork of the Neuroglancer client: Neuroglancer, which has added some light sheet specific features compared to its parent forks.
The entire application is containerized using Docker and Docker-compose.
Along with the main flask app, there is also a celery worker (see the "worker" service in the docker-compose*.yml files) that handles asynchronous tasks from the main flask app. A celery scheduler (the "scheduler" service) also submits tasks to this worker container independently of the main flask app. Scheduled tasks include checking on statuses of jobs submitted to the Princeton High Performance Computers, and checking for long-inactive neuroglancer and cloudvolume containers so that they can be removed as to limit resource usage by the application.
The service is hosted at https://braincogs00.pni.princeton.edu.
-
cloudvolume-docker/: docker files for spawning cloudvolumes -- these are used for hosting light sheet data so that it can be viewed in Neuroglancer
-
lib/: homemade python libraries
-
lightserv/: the main flask application
-
neuroglancer-docker/: docker files for spawning neuroglancer viewer links
-
schemas/: the database and table structure
-
viewer-launcher/: the docker container for a flask app serving as an API for the main flask app to spawn docker containers. The main flask app cannot do this itself because the conatiner user needs to be root in order to spawn docker containers via the docker socket, and the main flask app needs to be a non-root user in order to write to the Princeton file system. The viewer-launcher container is run as root so it can spawn the containers via the docker socket.
-
startup_scripts/docker-compose-dev.yml: the instructions file for running the development version of the flask app and its associated services.
-
startup_scripts/docker-compose-prod.yml: the instructions file for running the production version of the flask app and its associated services.
-
startup_scripts/docker-compose-test.yml: the instructions file for running the tests and its associated services.
-
flaskcelery.Dockerfile: The dockerfile used to build the image that is used by the main flask app and the celery worker and celery beat scheduler.
-
requirements.txt the requirements file for the flaskcelery image.
-
run.py The python script for starting the main flask app (it is run inside of a docker container).
-
lightserv/config.py Contains environmental variables used by Lightserv. Also contains the config for the scheduled celery tasks.
-
lightserv/init.py Makes the connection to the datajoint00 database server and creates the app and all of its blueprints.
This project is supported by the NIH Brain Research through Advancing Innovative Neurotechnologies (BRAIN) Initiative U19 grant.