From c2feaf6c60c913a271ef0c8150b14a444dcbf769 Mon Sep 17 00:00:00 2001 From: Jonas Hagberg Date: Thu, 9 Feb 2023 15:54:07 +0100 Subject: [PATCH] Added pgadmin container for production --- production.yml | 94 ++++++++++++++++++-------------- system/herdbook.standalone.nginx | 11 ++++ 2 files changed, 63 insertions(+), 42 deletions(-) diff --git a/production.yml b/production.yml index 06293e0a..8949bf1c 100644 --- a/production.yml +++ b/production.yml @@ -1,46 +1,56 @@ --- version: "3.4" services: - database: - restart: always - image: postgres:12 - container_name: herdbook-db - env_file: - - ./.docker/database-variables.env - environment: - - POSTGRES_HOST_AUTH_METHOD=trust - volumes: - - ./postgres-data:/var/lib/postgresql/data - main: - image: ghcr.io/nbisweden/herdbook_main:${TAG:?TAG-not-set} - container_name: herdbook-main - env_file: - - ./.docker/database-variables.env - - ./.docker/r-api-variables.env - - ./.docker/main-api-variables.env - ports: - - 80:8080 - - 443:8443 - - 9090:9090 - volumes: - - type: bind - source: ./app - target: /api_src - - type: bind - source: ./config - target: /config - - type: bind - source: ./logs - target: /logs - depends_on: - - database - - r-api - restart: always + database: + restart: always + image: postgres:12 + container_name: herdbook-db + env_file: + - ./.docker/database-variables.env + environment: + - POSTGRES_HOST_AUTH_METHOD=trust + volumes: + - ./postgres-data:/var/lib/postgresql/data + pgadmin: + restart: always + image: dpage/pgadmin4:latest + hostname: pgadmin + volumes: + - ./pgadmin:/var/lib/pgadmin + environment: + - PGADMIN_DEFAULT_EMAIL=UPDATEME + - PGADMIN_DEFAULT_PASSWORD=UPDATEME + - GUNICORN_ACCESS_LOGFILE=/dev/null + main: + image: ghcr.io/nbisweden/herdbook_main:${TAG:?TAG-not-set} + container_name: herdbook-main + env_file: + - ./.docker/database-variables.env + - ./.docker/r-api-variables.env + - ./.docker/main-api-variables.env + ports: + - 80:8080 + - 443:8443 + - 9090:9090 + volumes: + - type: bind + source: ./app + target: /api_src + - type: bind + source: ./config + target: /config + - type: bind + source: ./logs + target: /logs + depends_on: + - database + - r-api + restart: always - r-api: - image: ghcr.io/nbisweden/herdbook_r-api:${TAG:?TAG-not-set} - container_name: r-api - env_file: - - ./.docker/database-variables.env - - ./.docker/r-api-variables.env - restart: always + r-api: + image: ghcr.io/nbisweden/herdbook_r-api:${TAG:?TAG-not-set} + container_name: r-api + env_file: + - ./.docker/database-variables.env + - ./.docker/r-api-variables.env + restart: always diff --git a/system/herdbook.standalone.nginx b/system/herdbook.standalone.nginx index 27c1c3eb..20936249 100644 --- a/system/herdbook.standalone.nginx +++ b/system/herdbook.standalone.nginx @@ -43,4 +43,15 @@ # use its built in http server. proxy_pass http://127.0.0.1:9090/api/; } + + location ^~ /pgadmin { + proxy_pass http://pgadmin/; + proxy_http_version 1.1; + proxy_set_header X-Script-Name /pgadmin; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection 'upgrade'; + proxy_set_header Host $host; + proxy_cache_bypass $http_upgrade; + proxy_redirect off; + } }