Yes, I’m able to connect to the db from the backend container’s cli. Here is the pwd.yml file I’m using:
services:
backend:
image: frappe/erpnext:v15.48.2
networks:
- frappe
deploy:
restart_policy:
condition: on-failure
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
environment:
DB_HOST: ‘db_ip-address’
DB_PORT: ‘db_port’
DB_NAME: ‘db_name’
DB_USER: ‘db_user’
DB_PASSWORD: ‘db_password’
DB_TYPE: mariadb
configurator:
image: frappe/erpnext:v15.48.2
networks:
- frappe
deploy:
restart_policy:
condition: none
entrypoint:
- bash
- -c
command:
- >
ls -1 apps > sites/apps.txt;
bench set-config -g db_host $$DB_HOST;
bench set-config -gp db_port $$DB_PORT;
bench set-config -g db_name $$DB_NAME;
bench set-config -g db_user $$DB_USER;
bench set-config -g db_password $$DB_PASSWORD;
bench set-config -g db_type $$DB_TYPE;
bench set-config -g redis_cache “redis://$$REDIS_CACHE”;
bench set-config -g redis_queue “redis://$$REDIS_QUEUE”;
bench set-config -g redis_socketio “redis://$$REDIS_QUEUE”;
bench set-config -gp socketio_port $$SOCKETIO_PORT;
environment:
DB_HOST: ‘db_ip-address’
DB_PORT: ‘db_port’
DB_NAME: ‘db_name’
DB_USER: ‘db_user’
DB_PASSWORD: ‘db_password’
DB_TYPE: “mariadb”
REDIS_CACHE: redis-cache:6379
REDIS_QUEUE: redis-queue:6379
SOCKETIO_PORT: “9000”
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
create-site:
image: frappe/erpnext:v15.48.2
networks:
- frappe
deploy:
restart_policy:
condition: none
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
entrypoint:
- bash
- -c
command:
- >
wait-for-it -t 120 'db_ip-address:db_port;
wait-for-it -t 120 redis-cache:6379;
wait-for-it -t 120 redis-queue:6379;
export start=date +%s
;
until [[ -n grep -hs ^ sites/common_site_config.json | jq -r ".db_host // empty"
]] &&
[[ -n grep -hs ^ sites/common_site_config.json | jq -r ".redis_cache // empty"
]] &&
[[ -n grep -hs ^ sites/common_site_config.json | jq -r ".redis_queue // empty"
]];
do
echo “Waiting for sites/common_site_config.json to be created”;
sleep 5;
if (( date +%s
-start > 120 )); then
echo “could not find sites/common_site_config.json with required keys”;
exit 1
fi
done;
echo “sites/common_site_config.json found”;
bench new-site SITE --db-name DB_NAME --db-root-username DB_ROOT_USER --db-root-password DB_ROOT_PASSWORD --db-host DB_IP-ADDRESS --db-port DB_PORT --admin-password admin --install-app erpnext --force;
frontend:
image: frappe/erpnext:v15.48.2
networks:
- frappe
depends_on:
- websocket
deploy:
restart_policy:
condition: on-failure
command:
- nginx-entrypoint.sh
environment:
BACKEND: backend:8000
FRAPPE_SITE_NAME_HEADER:
SOCKETIO: websocket:9000
UPSTREAM_REAL_IP_ADDRESS: 127.0.0.1
UPSTREAM_REAL_IP_HEADER: X-Forwarded-For
UPSTREAM_REAL_IP_RECURSIVE: “off”
PROXY_READ_TIMEOUT: 120
CLIENT_MAX_BODY_SIZE: 50m
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
ports:
- “8080:8080”
queue-long:
image: frappe/erpnext:v15.48.2
networks:
- frappe
deploy:
restart_policy:
condition: on-failure
command:
- bench
- worker
- --queue
- long,default,short
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
queue-short:
image: frappe/erpnext:v15.48.2
networks:
- frappe
deploy:
restart_policy:
condition: on-failure
command:
- bench
- worker
- --queue
- short,default
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
redis-queue:
image: redis:6.2-alpine
networks:
- frappe
deploy:
restart_policy:
condition: on-failure
volumes:
- redis-queue-data:/data
redis-cache:
image: redis:6.2-alpine
networks:
- frappe
deploy:
restart_policy:
condition: on-failure
volumes:
- redis-cache-data:/data
scheduler:
image: frappe/erpnext:v15.48.2
networks:
- frappe
deploy:
restart_policy:
condition: on-failure
command:
- bench
- schedule
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
websocket:
image: frappe/erpnext:v15.48.2
networks:
- frappe
deploy:
restart_policy:
condition: on-failure
command:
- node
- /home/frappe/frappe-bench/apps/frappe/socketio.js
volumes:
- sites:/home/frappe/frappe-bench/sites
- logs:/home/frappe/frappe-bench/logs
volumes:
db-data:
redis-queue-data:
redis-cache-data:
sites:
logs:
networks:
frappe:
driver: bridge