Update Docker Compose scripts to resync with DSpace/DSpace

This commit is contained in:
Tim Donohue
2021-04-07 13:57:25 -05:00
parent f81acb575d
commit 1741678807
4 changed files with 71 additions and 22 deletions

View File

@@ -22,7 +22,8 @@ services:
networks: networks:
dspacenet: {} dspacenet: {}
environment: environment:
- LOADASSETS=https://www.dropbox.com/s/v3ahfcuatklbmi0/assetstore-2019-11-28.tar.gz?dl=1 # This assetstore zip is available from https://github.com/DSpace-Labs/AIP-Files/releases/tag/demo-entities-data
- LOADASSETS=https://github.com/DSpace-Labs/AIP-Files/releases/download/demo-entities-data/assetstore.tar.gz
entrypoint: entrypoint:
- /bin/bash - /bin/bash
- '-c' - '-c'

View File

@@ -19,4 +19,5 @@ services:
image: dspace/dspace-postgres-pgcrypto:loadsql image: dspace/dspace-postgres-pgcrypto:loadsql
environment: environment:
# This LOADSQL should be kept in sync with the URL in DSpace/DSpace # This LOADSQL should be kept in sync with the URL in DSpace/DSpace
- LOADSQL=https://www.dropbox.com/s/4ap1y6deseoc8ws/dspace7-entities-2019-11-28.sql?dl=1 # This SQL is available from https://github.com/DSpace-Labs/AIP-Files/releases/tag/demo-entities-data
- LOADSQL=https://github.com/DSpace-Labs/AIP-Files/releases/download/demo-entities-data/dspace7-entities-2021-04-14.sql

View File

@@ -8,9 +8,13 @@
# Docker Compose for running the DSpace backend for e2e testing in a CI environment # Docker Compose for running the DSpace backend for e2e testing in a CI environment
# This is used by our GitHub CI at .github/workflows/build.yml # This is used by our GitHub CI at .github/workflows/build.yml
# It is based heavily on the Backend's Docker Compose:
# https://github.com/DSpace/DSpace/blob/main/docker-compose.yml
version: '3.7'
networks: networks:
dspacenet: dspacenet:
services: services:
# DSpace (backend) webapp container
dspace: dspace:
container_name: dspace container_name: dspace
depends_on: depends_on:
@@ -26,12 +30,26 @@ services:
volumes: volumes:
- assetstore:/dspace/assetstore - assetstore:/dspace/assetstore
- "./local.cfg:/dspace/config/local.cfg" - "./local.cfg:/dspace/config/local.cfg"
# Ensure that the database is ready BEFORE starting tomcat
# 1. While a TCP connection to dspacedb port 5432 is not available, continue to sleep
# 2. Then, run database migration to init database tables
# 3. Finally, start Tomcat
entrypoint:
- /bin/bash
- '-c'
- |
while (!</dev/tcp/dspacedb/5432) > /dev/null 2>&1; do sleep 1; done;
/dspace/bin/dspace database migrate
catalina.sh run
# DSpace database container
# NOTE: This is customized to use our loadsql image, so that we are using a database with existing test data
dspacedb: dspacedb:
container_name: dspacedb container_name: dspacedb
environment: environment:
# This LOADSQL should be kept in sync with the LOADSQL in # This LOADSQL should be kept in sync with the LOADSQL in
# https://github.com/DSpace/DSpace/blob/main/dspace/src/main/docker-compose/db.entities.yml # https://github.com/DSpace/DSpace/blob/main/dspace/src/main/docker-compose/db.entities.yml
LOADSQL: https://www.dropbox.com/s/4ap1y6deseoc8ws/dspace7-entities-2019-11-28.sql?dl=1 # This SQL is available from https://github.com/DSpace-Labs/AIP-Files/releases/tag/demo-entities-data
LOADSQL: https://github.com/DSpace-Labs/AIP-Files/releases/download/demo-entities-data/dspace7-entities-2021-04-14.sql
PGDATA: /pgdata PGDATA: /pgdata
image: dspace/dspace-postgres-pgcrypto:loadsql image: dspace/dspace-postgres-pgcrypto:loadsql
networks: networks:
@@ -40,9 +58,11 @@ services:
tty: true tty: true
volumes: volumes:
- pgdata:/pgdata - pgdata:/pgdata
# DSpace Solr container
dspacesolr: dspacesolr:
container_name: dspacesolr container_name: dspacesolr
image: dspace/dspace-solr # Uses official Solr image at https://hub.docker.com/_/solr/
image: solr:8.8
networks: networks:
dspacenet: dspacenet:
ports: ports:
@@ -50,16 +70,27 @@ services:
target: 8983 target: 8983
stdin_open: true stdin_open: true
tty: true tty: true
working_dir: /var/solr/data
volumes: volumes:
- solr_authority:/opt/solr/server/solr/authority/data # Mount our local Solr core configs so that they are available as Solr configsets on container
- solr_oai:/opt/solr/server/solr/oai/data - ./dspace/solr/authority:/opt/solr/server/solr/configsets/authority
- solr_search:/opt/solr/server/solr/search/data - ./dspace/solr/oai:/opt/solr/server/solr/configsets/oai
- solr_statistics:/opt/solr/server/solr/statistics/data - ./dspace/solr/search:/opt/solr/server/solr/configsets/search
version: '3.7' - ./dspace/solr/statistics:/opt/solr/server/solr/configsets/statistics
# Keep Solr data directory between reboots
- solr_data:/var/solr/data
# Initialize all DSpace Solr cores using the mounted local configsets (see above), then start Solr
entrypoint:
- /bin/bash
- '-c'
- |
init-var-solr
precreate-core authority /opt/solr/server/solr/configsets/authority
precreate-core oai /opt/solr/server/solr/configsets/oai
precreate-core search /opt/solr/server/solr/configsets/search
precreate-core statistics /opt/solr/server/solr/configsets/statistics
exec solr -f
volumes: volumes:
assetstore: assetstore:
pgdata: pgdata:
solr_authority: solr_data:
solr_oai:
solr_search:
solr_statistics:

View File

@@ -14,6 +14,7 @@ version: '3.7'
networks: networks:
dspacenet: dspacenet:
services: services:
# DSpace (backend) webapp container
dspace: dspace:
container_name: dspace container_name: dspace
image: dspace/dspace:dspace-7_x-test image: dspace/dspace:dspace-7_x-test
@@ -40,6 +41,7 @@ services:
while (!</dev/tcp/dspacedb/5432) > /dev/null 2>&1; do sleep 1; done; while (!</dev/tcp/dspacedb/5432) > /dev/null 2>&1; do sleep 1; done;
/dspace/bin/dspace database migrate /dspace/bin/dspace database migrate
catalina.sh run catalina.sh run
# DSpace database container
dspacedb: dspacedb:
container_name: dspacedb container_name: dspacedb
environment: environment:
@@ -54,9 +56,11 @@ services:
tty: true tty: true
volumes: volumes:
- pgdata:/pgdata - pgdata:/pgdata
# DSpace Solr container
dspacesolr: dspacesolr:
container_name: dspacesolr container_name: dspacesolr
image: dspace/dspace-solr # Uses official Solr image at https://hub.docker.com/_/solr/
image: solr:8.8
networks: networks:
dspacenet: dspacenet:
ports: ports:
@@ -64,15 +68,27 @@ services:
target: 8983 target: 8983
stdin_open: true stdin_open: true
tty: true tty: true
working_dir: /var/solr/data
volumes: volumes:
- solr_authority:/opt/solr/server/solr/authority/data # Mount our local Solr core configs so that they are available as Solr configsets on container
- solr_oai:/opt/solr/server/solr/oai/data - ./dspace/solr/authority:/opt/solr/server/solr/configsets/authority
- solr_search:/opt/solr/server/solr/search/data - ./dspace/solr/oai:/opt/solr/server/solr/configsets/oai
- solr_statistics:/opt/solr/server/solr/statistics/data - ./dspace/solr/search:/opt/solr/server/solr/configsets/search
- ./dspace/solr/statistics:/opt/solr/server/solr/configsets/statistics
# Keep Solr data directory between reboots
- solr_data:/var/solr/data
# Initialize all DSpace Solr cores using the mounted local configsets (see above), then start Solr
entrypoint:
- /bin/bash
- '-c'
- |
init-var-solr
precreate-core authority /opt/solr/server/solr/configsets/authority
precreate-core oai /opt/solr/server/solr/configsets/oai
precreate-core search /opt/solr/server/solr/configsets/search
precreate-core statistics /opt/solr/server/solr/configsets/statistics
exec solr -f
volumes: volumes:
assetstore: assetstore:
pgdata: pgdata:
solr_authority: solr_data:
solr_oai:
solr_search:
solr_statistics: