If you wish to run DSpace on Docker in production, we recommend building your own Docker images. You are welcome to borrow ideas/concepts from the below images in doing so. But, the below images should not be used "as is" in any production scenario.
The Dockerfiles in this directory (and subdirectories) are used by our Docker Compose scripts.
This Dockerfile is used to pre-cache Maven dependency downloads that will be used in subsequent DSpace docker builds. Caching these Maven dependencies provides a speed increase to all later builds by ensuring the dependencies are only downloaded once.
docker build -t dspace/dspace-dependencies:latest -f Dockerfile.dependencies .
This image is built automatically after each commit is made to the main
branch.
Admins to our DockerHub repo can manually publish with the following command.
docker push dspace/dspace-dependencies:latest
This Dockerfile builds a DSpace REST API backend image (for testing/development). This image deploys one webapp to Tomcat running in Docker:
- The DSpace REST API (at
http://localhost:8080/server
) This image also sets up debugging in Tomcat for development.
docker build -t dspace/dspace:latest-test -f Dockerfile.test .
This image is built automatically after each commit is made to the main
branch.
Admins to our DockerHub repo can manually publish with the following command.
docker push dspace/dspace:latest-test
This Dockerfile builds a DSpace REST API backend image. This image deploys one DSpace webapp to Tomcat running in Docker:
- The DSpace REST API (at
http://localhost:8080/server
)
docker build -t dspace/dspace:latest -f Dockerfile .
This image is built automatically after each commit is made to the main
branch.
Admins to our DockerHub repo can publish with the following command.
docker push dspace/dspace:latest
This Dockerfile builds a DSpace CLI (command line interface) image, which can be used to run DSpace's commandline tools via Docker.
docker build -t dspace/dspace-cli:latest -f Dockerfile.cli .
This image is built automatically after each commit is made to the main
branch.
Admins to our DockerHub repo can publish with the following command.
docker push dspace/dspace-cli:latest
This is a PostgreSQL Docker image containing the pgcrypto
extension required by DSpace 6+.
This image is built automatically after each commit is made to the main
branch.
How to build manually:
cd dspace/src/main/docker/dspace-postgres-pgcrypto
docker build -t dspace/dspace-postgres-pgcrypto:latest .
It is also possible to change the version of PostgreSQL or the PostgreSQL user's password during the build:
cd dspace/src/main/docker/dspace-postgres-pgcrypto
docker build -t dspace/dspace-postgres-pgcrypto:latest --build-arg POSTGRES_VERSION=11 --build-arg POSTGRES_PASSWORD=mypass .
Admins to our DockerHub repo can (manually) publish with the following command.
docker push dspace/dspace-postgres-pgcrypto:latest
This is a PostgreSQL Docker image containing the pgcrypto
extension required by DSpace 6+.
This image also contains curl
. The image is pre-configured to load a Postgres database dump on initialization.
This image is built automatically after each commit is made to the main
branch.
How to build manually:
cd dspace/src/main/docker/dspace-postgres-pgcrypto-curl
docker build -t dspace/dspace-postgres-pgcrypto:latest-loadsql .
Similar to dspace-postgres-pgcrypto
above, you can also modify the version of PostgreSQL or the PostgreSQL user's password.
See examples above.
Admins to our DockerHub repo can (manually) publish with the following command.
docker push dspace/dspace-postgres-pgcrypto:latest-loadsql
This is a test / demo image which provides an Apache HTTPD proxy (in front of Tomcat)
with mod_shib
& Shibboleth installed based on the
DSpace Shibboleth configuration instructions.
It is primarily for usage for testing DSpace's Shibboleth integration.
It uses https://samltest.id/ as the Shibboleth IDP
This image is built manually. It should be rebuilt as needed.
cd dspace/src/main/docker/dspace-shibboleth
docker build -t dspace/dspace-shibboleth .
# Test running it manually
docker run -i -t -d -p 80:80 -p 443:443 dspace/dspace-shibboleth
This image can also be rebuilt using the ../docker-compose/docker-compose-shibboleth.yml
script.
This Dockerfile builds a Solr image with DSpace Solr configsets included. It can be pulled / built following the docker compose resources documentation. Or, to just build and/or run Solr:
docker-compose build dspacesolr
docker-compose -p d8 up -d dspacesolr
If you're making iterative changes to the DSpace Solr configsets you'll need to rebuild /
restart the dspacesolr
container for the changes to be deployed. From DSpace root:
docker-compose -p d8 up --detach --build dspacesolr
These resources are bundled into the dspace/dspace:dspace-*-test
image at build time.
See the Dockerfile.test
section above for more information about the test image.
When updating or debugging Docker image builds, it can be useful to briefly spin up an "intermediate container". Here's how to do that:
# First find the intermediate container/image ID in your commandline logs
docker run -i -t [container-id] /bin/bash