Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to rebuild and update a container without downtime with docker-compose?

I enjoy a lot using docker-compose.

Eg. on my server, when I want to update my app with minor changes, I only need to git pull origin master && docker-compose restart, works perfectly.

But sometimes, I need to rebuild (eg. I added an npm dependency, need to run npm install again).

In this case, I do docker-compose build --no-cache && docker-compose restart.

I would expect this to :

  • create a new instance of my container
  • stop the existing container (after the newer has finished building)
  • start the new one
  • optionally remove the old one, but this could be done manually

But in practice it seems to restart the former one again.

Is it the expected behavior?

How can I handle a rebuild and start the new one after it is built?

Maybe I missed a specific command? Or would it make sense to have it?

like image 937
Augustin Riedinger Avatar asked Mar 01 '17 10:03

Augustin Riedinger


People also ask

How do I deploy docker without downtime?

you should use docker-compose up first of all if its your first time your deploy code. and then run the update_server script to update your changes without any downtime.

How do I keep my docker containers updated?

The easy solution to keeping your Docker containers updated is simply to add another container, Watchtower. This simple image will watch your existing containers and upgrade them as newer builds are released, no questions asked.


Video Answer


2 Answers

from the manual docker-compose restart

If you make changes to your docker-compose.yml configuration these changes will not be reflected after running this command.

you should be able to do

$docker-compose up -d --no-deps --build <service_name> 

The --no-deps will not start linked services.

like image 94
denov Avatar answered Sep 28 '22 06:09

denov


The problem is that restart will restart your current containers, which is not what you want.

As an example, I just did this

  • change the docker file for one of the images
  • call docker-compose build to build the images
  • call docker-compose down1 and docker-compose up
    • docker-compose restart will NOT work here
    • using docker-compose start instead also does not work

To be honest, i'm not completly sure you need to do a down first, but that should be easy to check.1 The bottomline is that you need to call up. You will see the containers of unchanged images restarting, but for the changed image you'll see recreating.

The advantage of this over just calling up --build is that you can see the building-process first before you restart.

1: from the comments; down is not needed, you can just call up --build. Down has some "down"-sides, including possible being destructive to your (volume-)data.

like image 37
Nanne Avatar answered Sep 28 '22 06:09

Nanne