version: "3" volumes: ckan_storage: pg_data: solr_data: services: apache: container_name: ${APACHE_CONTAINER_NAME} build: context: apache/ dockerfile: Dockerfile env_file: - .env logging: driver: "json-file" options: max-size: "100m" max-file: "10" networks: - webnet - ckannet depends_on: ckan: condition: service_healthy ports: - "0.0.0.0:${APACHE_PORT_HOST}:${APACHE_PORT}" ckan: container_name: ${CKAN_CONTAINER_NAME} build: context: ckan/ dockerfile: Dockerfile.ghcr args: - TZ=${TZ} networks: - ckannet - dbnet - solrnet - redisnet env_file: - .env logging: driver: "json-file" options: max-size: "100m" max-file: "10" depends_on: db: condition: service_healthy solr: condition: service_healthy redis: condition: service_healthy volumes: - ckan_storage:/var/lib/ckan restart: unless-stopped healthcheck: test: ["CMD", "wget", "-qO", "/dev/null", "http://localhost:${CKAN_PORT}"] pycsw: container_name: ${PYCSW_CONTAINER_NAME} build: context: ckan-pycsw/ dockerfile: Dockerfile env_file: - .env logging: driver: "json-file" options: max-size: "100m" max-file: "10" networks: - webnet - ckannet depends_on: ckan: condition: service_healthy ports: - "0.0.0.0:${PYCSW_PORT_HOST}:${PYCSW_PORT}" volumes: - ./log:${APP_DIR}/log - ./metadata:${APP_DIR}/metadata restart: on-failure:3 healthcheck: test: ["CMD", "wget", "-qO", "/dev/null", "http://localhost:${PYCSW_PORT}"] db: container_name: ${POSTGRESQL_CONTAINER_NAME} build: context: postgresql/ networks: - dbnet environment: - POSTGRES_USER - POSTGRES_PASSWORD - POSTGRES_DB - CKAN_DB_USER - CKAN_DB_PASSWORD - CKAN_DB - DATASTORE_READONLY_USER - DATASTORE_READONLY_PASSWORD - DATASTORE_DB volumes: - pg_data:/var/lib/postgresql/data logging: driver: "json-file" options: max-size: "100m" max-file: "10" restart: unless-stopped healthcheck: test: ["CMD", "pg_isready", "-U", "${POSTGRES_USER}", "-d", "${POSTGRES_DB}"] solr: container_name: ${SOLR_CONTAINER_NAME} build: context: solr/ dockerfile: Dockerfile.spatial networks: - solrnet env_file: - .env logging: driver: "json-file" options: max-size: "100m" max-file: "10" volumes: - solr_data:/var/solr restart: unless-stopped healthcheck: test: ["CMD", "wget", "-qO", "/dev/null", "http://localhost:${SOLR_PORT}/solr/"] redis: container_name: ${REDIS_CONTAINER_NAME} image: redis:${REDIS_VERSION} logging: driver: "json-file" options: max-size: "100m" max-file: "10" networks: - redisnet restart: unless-stopped healthcheck: test: ["CMD", "redis-cli", "-e", "QUIT"] networks: webnet: ckannet: solrnet: internal: true dbnet: internal: true redisnet: internal: true