Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add pgAdmin to docker compose for nice local admin UI #255

Merged
merged 8 commits into from
Dec 3, 2024
50 changes: 46 additions & 4 deletions docker-compose.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
version: "3.7"
services:
admin_backend_db:
image: postgres:14
Expand All @@ -10,7 +9,7 @@ services:
volumes:
- admin-data:/var/lib/postgresql/data:cached
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER}"]
test: [CMD-SHELL, "pg_isready -U ${POSTGRES_USER}"]
interval: 5s
timeout: 3s
retries: 30
Expand All @@ -32,6 +31,49 @@ services:
depends_on:
admin_backend_db:
condition: service_healthy

pgadmin:
image: dpage/pgadmin4
container_name: pgadmin4
restart: always
env_file:
- .env
ports:
- 8000:80
# This has to have world & group access denied to work
entrypoint: /bin/sh -c "chmod 600 /pgpass; /entrypoint.sh;"
configs:
- source: servers.json
target: /pgadmin4/servers.json
- source: pgpass
target: /pgpass
environment:
# This deavctivates the login screen
PGADMIN_CONFIG_SERVER_MODE: "False"
PGADMIN_CONFIG_MASTER_PASSWORD_REQUIRED: "False"
volumes:
- pgadmin-data:/var/lib/pgadmin
# This is just nice to know as if it fails, it fails quietly
healthcheck:
test: [CMD, wget, -O, "-", http://localhost:80/misc/ping]
configs:
pgpass:
jamesgorrie marked this conversation as resolved.
Show resolved Hide resolved
content: "admin_backend_db:5432:*:${POSTGRES_USER}:${POSTGRES_PASSWORD}"
servers.json:
jamesgorrie marked this conversation as resolved.
Show resolved Hide resolved
content: |
{
"Servers": {
"1": {
"Group": "Servers",
"Name": "Navigator Admin Backend",
"Host": "admin_backend_db",
"Port": 5432,
jamesgorrie marked this conversation as resolved.
Show resolved Hide resolved
"MaintenanceDB": "postgres",
"Username": "${POSTGRES_USER}",
"Password": "${POSTGRES_PASSWORD}",
"SSLMode": "prefer"
}
}
}
volumes:
admin-data:
admin-data: {}
pgadmin-data: {}
Loading