Skip to content

MaastrichtU-Library/omekas-docker

Repository files navigation

Omeka S docker

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.

Preparation

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:

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.

Set configuration options in .env file

  1. Open the .env file in a text editor.
  2. Change values accordingly. E.g. change module versions. hostnames, etc.

Build instructions

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 instructions

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

Manual configurations post-start

There are some manual configuration steps to perform after the Docker containers have started.

Usage

When all containers have started, you will find the services at the following URLs:

Remove all containers and data

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

Troubleshooting and debugging

There are several ways to troubleshoot errors in Omeka S.

  1. 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.
  2. 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
    
  3. 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"
    
  4. 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.