How to force Docker for a clean build of an image

后端 未结 9 952
情书的邮戳
情书的邮戳 2021-01-29 17:12

I have build a Docker image from a Docker file using the below command.

$ docker build -t u12_core -f u12_core .

When I am trying to rebuild it

9条回答
  •  时光取名叫无心
    2021-01-29 17:39

    Most of information here are correct.
    Here a compilation of them and my way of using them.

    The idea is to stick to the recommended approach (build specific and no impact on other stored docker objects) and to try the more radical approach (not build specific and with impact on other stored docker objects) when it is not enough.

    Recommended approach :

    1) Force the execution of each step/instruction in the Dockerfile :

    docker build --no-cache 
    

    or with docker-compose build :

    docker-compose build --no-cache
    

    We could also combine that to the up sub-command that recreate all containers:

    docker-compose build --no-cache &&
    docker-compose up -d --force-recreate 
    

    These way don't use cache but for the docker builder and the base image referenced with the FROM instruction.

    2) Wipe the docker builder cache (if we use Buildkit we very probably need that) :

    docker builder prune -af
    

    3) If we don't want to use the cache of the parent images, we may try to delete them such as :

    docker image rm -f fooParentImage
    

    In most of cases, these 3 things are perfectly enough to allow a clean build of our image.
    So we should try to stick to that.

    More radical approach :

    In corner cases where it seems that some objects in the docker cache are still used during the build and that looks repeatable, we should try to understand the cause to be able to wipe the missing part very specifically. If we really don't find a way to rebuild from scratch, there are other ways but it is important to remember that these generally delete much more than it is required. So we should use them with cautious overall when we are not in a local/dev environment.

    1) Remove all images without at least one container associated to them :

    docker image prune -a
    

    2) Remove many more things :

    docker system prune -a
    

    That says :

    WARNING! This will remove:
      - all stopped containers
      - all networks not used by at least one container
      - all images without at least one container associated to them
      - all build cache
    

    Using that super delete command may not be enough because it strongly depends on the state of containers (running or not). When that command is not enough, I try to think carefully which docker containers could cause side effects to our docker build and to allow these containers to be exited in order to allow them to be removed with the command.

提交回复
热议问题