PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Docker attende che postgresql sia in esecuzione

Ho passato alcune ore a indagare su questo problema e ho trovato una soluzione. Docker depends_on considera solo l'avvio del servizio per eseguire un altro servizio. Poi succede perché non appena db viene avviato, l'app di servizio tenta di connettersi a ur db , ma non è pronto per ricevere connessioni. Quindi puoi controllare db stato di integrità nel servizio app per attendere la connessione. Ecco la mia soluzione, ha risolto il mio problema. :)Importante:sto usando docker-compose versione 2.1.

version: '2.1'

services:
  my-app:
    build: .
    command: su -c "python manage.py runserver 0.0.0.0:8000"
    ports:
       - "8000:8000"
    depends_on:
      db:
        condition: service_healthy
    links:
      - db
    volumes:
      - .:/app_directory

  db:
    image: postgres:10.5
    ports:
      - "5432:5432"
    volumes:
      - database:/var/lib/postgresql/data
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 5s
      timeout: 5s
      retries: 5

volumes:
  database:

In questo caso non è necessario creare un file .sh. Spero di esservi stato d'aiuto ragazzi;)cya