Contexto: docker-componha para iniciar vários contêineres, incluindo o Gunicorn que chama um aplicativo Flask. Estou usando um arquivo de ambiente web/env.gunicorn
para armazenar minha configuração de inicialização do Gunicorn. Este arquivo contém
GUNICORN_CMD_ARGS="--bind=127.0.0.1:8001 --workers=3"
O problema é que GUNICORN_CMD_ARGS
não é processado corretamente em algum lugar do pipeline. O erro que recebo ao executar docker logs gunicorn
é
Error: '8001 --workers=3' is not a valid port number.
A questão é: onde na minha configuração minhas suposições estão erradas, fazendo com que a variável de ambiente seja mutilada? A variável de ambiente é aceita quando executada manualmente em um terminal. O arquivo de composição do docker tem a seguinte aparência
version: "3"
services:
# nginx:
# image: nginx:latest
# ports:
# - "80:80"
# volumes:
# - ./nginx:/etc/nginx/conf.d
# depends_on:
# - web
web:
build: ./web
container_name: gunicorn
ports:
- "8001:8001"
environment:
- APP_CONFIG_FILE=../config/development.py
env_file:
- 'web/env.gunicorn'
networks:
- backend
command: gunicorn thymedata:app
depends_on:
- influxdb
- grafana
influxdb:
image: influxdb:latest
container_name: influxdb
ports:
- "8086:8086"
env_file:
- 'influxdb/env.influxdb'
- 'influxdb/secrets.influxdb'
networks:
- backend
volumes:
- influxdb-data:/var/lib/influxdb
grafana:
image: grafana/grafana:latest
container_name: grafana
ports:
- "3000:3000"
env_file:
- 'grafana/env.grafana'
- 'grafana/secrets.grafana'
networks:
- backend
volumes:
- grafana-data:/var/lib/grafana
depends_on:
- influxdb
networks:
backend:
volumes:
influxdb-data:
grafana-data:
GUNICORN_CMD_ARGS
set, e ele o aceitou corretamente (número de trabalhadores e endereço verificado). É por isso que suponho que o problema esteja do lado de Docker.
ERROR: build path /home/ben/devopsStackExchange/web either does not exist, is not accessible, or is not a valid URL.
. Crie steps to reproduce paragraph
e adicione os arquivos necessários para que outras pessoas possam ajudá-lo, pelo menos, permitindo que elas reproduzam o problema.
command: gunicorn thymedata:app --bind=127.0.0.1:8001 --workers=3
versão, pois as variáveis carregadas via env_file
não são aceitas. Eles já devem estar configurados no terminal de chamada.