Maastricht University Library maintained Omeka S Docker environment. Based on the official PHP-FPM image on Docker Hub and customized for our needs.
Credits to the setup by 'giocomai' Docker Hub | GitHub which was very inspirational in creating this Docker environment.
Edit /etc/hosts file
In order to resolve DNS entries to the Dockerized Omeka S infra, you need to edit /etc/hosts
on your host machine. Insert the following line that points all containers to 127.0.0.1
.
127.0.0.1 localhost omeka.local solr.local db.local iipsrv.local cantaloupe.local viewer.local
Load external dependencies
After initial clone of this git repository you will have an empty externals/
directory.
For proper Omeka S experience, docker-compose.yml
will volume bind additional stuff from other git repositories into the Omeka S container.
List of externals:
- Various helper scripts, e.g. ARK resolving: omekas-helpers
- UB Theme for Omeka S: omekas-theme-um
Execute the commands below to populate the externals folder.
cd externals/
git clone https://github.com/MaastrichtU-Library/omekas-helpers.git
git clone https://github.com/MaastrichtU-Library/omekas-theme-um.git
IMPORTANT: The externals repositories are not automatically updated locally, so make sure to git pull
changes
from those repositories periodically.
- Open the
.env
file in a text editor. - Change values accordingly. E.g. change module versions. hostnames, etc.
Build the Omeka S infra with:
docker compose build
Additionally, to build the external IIIF-tooling, use:
docker compose -f docker-compose-iiif-external.yml build
Run the Omeka S infra with:
docker compose up -d
To run external IIIF-tooling as well, use:
docker compose -f docker-compose-iiif-external.yml up -d
To see logs:
docker compose logs -f
There are some manual configuration steps to perform after the Docker containers have started.
When all containers have started, you will find the services at the following URLs:
- Omeka S: http://omeka.local (usr/pwd: admin@example.org / foobar)
- mySQL backend: http://db.local
- Solr backend: http://solr.local
- IIP IIIF server: http://iipsrv.local
- Cantaloupe IIIF server: http://cantaloupe.local (usr/pwd: admin / foobar)
- Mirador external IIIF viewer: http://viewer.local
Omeka and Solr config settings, data and files are saved in persistent docker volumes. Execute these commands to delete all data and go back to an empty, fresh experience.
Please remember to redo the manual configuration actions Configure Solr backend after creating the fresh environment.
Briefly:
# Stop and remove everything
docker compose down && docker volume rm omekas-docker_db omekas-docker_omeka omekas-docker_solrdata
# Start everything
docker compose up -d
# Redo the manual config actions
Detailed
docker compose down
docker volume ls
# This list all docker volumes on your machine. There should be entries like
# DRIVER VOLUME NAME
# local omekas-docker_db
# local omekas-docker_omeka
# local omekas-docker_solrdata
docker volume rm omekas-docker_db omekas-docker_omeka omekas-docker_solrdata
# Start everything
docker compose up -d
# Redo the manual config actions
There are several ways to troubleshoot errors in Omeka S.
- Use the Log module in Omeka's admin panel. Omeka errors that are usually written to the application.log file are also stored in the database so that they can be viewed in the Log admin panel.
- Docker logs. The output of various Omeka and Apache logs files is piped to the Docker logs. This is defined in the
omeka-s/docker-entrypoint.sh
file. You can inspect the log entries using one of the commands below.# For Omeka S only: docker compose logs -f omekas # Or for the whole compose project: docker compose logs -f
- Omeka S debug mode. Some errors are not written to the logs and can only be viewed in the web browser. To enable this, put Omeka to development mode in the
omeka-s/.htaccess
file.SetEnv APPLICATION_ENV "development"
- Remote debugging in PhpStorm. When developing theme- or module-code it is recommended to use the debugging capabilities of Xdebug and PhpStorm. Please read the PhpStorm Xdebug instructions.