Solución:
Es muy simple: usa el comando:
docker-compose restart worker
Puede establecer el tiempo de espera para detener antes de matar el contenedor (en segundos)
docker-compose restart -t 30 worker
Tenga en cuenta que esto reiniciará el contenedor pero sin reconstruirlo. Si desea aplicar sus cambios y luego reiniciar, eche un vistazo a las otras respuestas.
Las otras respuestas para reiniciar un solo nodo están en el objetivo, docker-compose restart worker
. Eso rebotará ese contenedor, pero no incluirá ningún cambio, incluso si lo reconstruye por separado. Puede manualmente stop
, rm
, create
, y start
, pero hay métodos mucho más sencillos.
Si actualizó su código, puede compilar y recargar en un solo paso con:
docker-compose up --detach --build
Eso primero reconstruirá sus imágenes a partir de cualquier código cambiado, lo cual es rápido si no hay cambios desde que se reutiliza el caché. Y luego solo reemplaza los contenedores cambiados. Si sus imágenes descargadas están obsoletas, puede preceder el comando anterior con:
docker-compose pull
Para descargar primero las imágenes modificadas (los contenedores no se reiniciarán hasta que ejecute un comando como el up
encima). No es necesario hacer una parada inicial.
Y para hacer esto solo para un único servicio, siga el comando up o pull con los servicios que desea especificar, por ejemplo:
docker-compose up --detach --build worker
Aquí hay un ejemplo rápido de la primera opción, el Dockerfile está estructurado para mantener las partes del código que cambian con frecuencia cerca del final. De hecho, los requisitos se extraen por separado para el pip install
ya que ese archivo rara vez cambia. Y dado que los contenedores nginx y redis estaban actualizados, no se reiniciaron. El tiempo total para todo el proceso fue de menos de 6 segundos:
$ time docker-compose -f docker-compose.nginx-proxy.yml up --detach --build
Building counter
Step 1 : FROM python:2.7-alpine
---> fc479af56697
Step 2 : WORKDIR /app
---> Using cache
---> d04d0d6d98f1
Step 3 : ADD requirements.txt /app/requirements.txt
---> Using cache
---> 9c4e311f3f0c
Step 4 : RUN pip install -r requirements.txt
---> Using cache
---> 85b878795479
Step 5 : ADD . /app
---> 63e3d4e6b539
Removing intermediate container 9af53c35d8fe
Step 6 : EXPOSE 80
---> Running in a5b3d3f80cd4
---> 4ce3750610a9
Removing intermediate container a5b3d3f80cd4
Step 7 : CMD gunicorn app:app -b 0.0.0.0:80 --log-file - --access-logfile - --workers 4 --keep-alive 0
---> Running in 0d69957bda4c
---> d41ff1635cb7
Removing intermediate container 0d69957bda4c
Successfully built d41ff1635cb7
counter_nginx_1 is up-to-date
counter_redis_1 is up-to-date
Recreating counter_counter_1
real 0m5.959s
user 0m0.508s
sys 0m0.076s
Para reiniciar un servicio con cambios, aquí están los pasos que realicé:
docker-compose stop -t 1 worker
docker-compose build worker
docker-compose up --no-start worker
docker-compose start worker