This is the repository for the Henslowe-Alleyn Digitisation Project at Kings Digital Lab.
The project has been containerised using Docker Compose. The containerised setup includes the following services:
kdl-apache-proxy
: This service provides a reverse proxy for the edition, routing requests to the appropriate backend service.django
: This services runs the Django application, providing the core functionality/frontend of the edition.postgres
: This service provides a Postgres database for the Django application.cantaloupe
: This service provides a JPG2000 image server for the project, providing high-quality images for the edition.
Follow these steps to set up and run the project using Docker Compose.
Note that these instructions cover only the local setup; server deployment is not covered here.
Before you begin, ensure you have the following installed on your system:
- Clone this repository
- Set up the environment file
Create a .env
file inside the compose directory with the following content:
# Set to false in production
DEBUG=true
# Set to true in production
PRODUCTION=false
DJANGO_ALLOWED_HOSTS=henslowe-alleyn.org.uk,henslowe-os.kdl.kcl.ac.uk,django,localhost,127.0.0.1
DJANGO_ADMINS=("Name", "[email protected]")
DJANGO_SECRET_KEY=generated_secret_key
[email protected]
DJANGO_EMAIL_HOST=smtp.example.com
DJANGO_EMAIL_PORT=25
POSTGRES_HOST=db
POSTGRES_PORT=5432
POSTGRES_DB=db_name
POSTGRES_USER=db_user
POSTGRES_PASSWORD=db_password
Ensure to replace the placeholder values with your own values.
-
Start the services
Use the provided helper script
docker.sh
to build and start the services:cd compose docker compose up --build
-
Access the application
Once all services are running, you can access the web application via your web browser at http://localhost/.
To stop the application press CTRL+C in the same terminal window where the
docker compose
command is running.
-
Restore the database
To restore the database from a backup file, place the backup file in the
volumes/db_backups
directory and run the following command:docker compose exec db restore db_backup_name.sql.gz
Note Django may need to be stopped before restoring the database. In any case, it is recommended to restart the services after restoring the database.