docker build не показывает никаких выходных данных из команд (RUN в Dockerfile)
Описание проблемы
Вот содержимое Dockerfile:
FROM alpine
ADD . /app/
WORKDIR /app
RUN echo "hello world"
RUN ls -l
При использовании Docker для выполнения сборки я обнаружил, что команда RUN не показывает результат работы.
Иногда при отладке требуется вывести содержимое директории или переменной.
❯ docker build -t test -f Dockerfile .
[+] Building 1.0s (10/10) FINISHED
=> [internal] load build definition from Dockerfile 0.0s
=> => transferring dockerfile: 112B 0.0s
=> [internal] load .dockerignore 0.0s
=> => transferring context: 2B 0.0s
=> [internal] load metadata for docker.io/library/alpine:latest 0.0s
=> [internal] load build context 0.0s
=> => transferring context: 107B 0.0s
=> CACHED [1/5] FROM docker.io/library/alpine 0.0s
=> [2/5] ADD . /app/ 0.0s
=> [3/5] WORKDIR /app 0.0s
=> [4/5] RUN echo "hello world" 0.4s
=> [5/5] RUN ls -l 0.4s
=> exporting to image 0.1s
=> => exporting layers 0.0s
=> => writing image sha256:123 0.0s
=> => naming to docker.io/library/test
Это очень неудобно именно для отладки при создании образов.
Решение
Добавьте DOCKER_BUILDKIT=0
перед командой docker build
, чтобы отображать результат работы команды.
❯ DOCKER_BUILDKIT=0 docker build -t test -f Dockerfile .
Sending build context to Docker daemon 2.048kB
Step 1/5 : FROM alpine
---> 183faf728851
Step 2/5 : ADD . /app/
---> 34cccaf2b826
Step 3/5 : WORKDIR /app
---> Running in 11eefb594656
Removing intermediate container 11eefb594656
---> 07582a62e423
Step 4/5 : RUN echo "hello world"
---> Running in dcc093d3310
hello world
Removing intermediate container bcd94b080379
---> 6fbc11007cff
Step 5/5 : RUN ls -l
---> Running in 8d9423839270
total 4
-rw-r--r-- 1 root root 70 Apr 29 03:07 Dockerfile
Removing intermediate container 8d9423839270
---> 7b6aee767fab
Successfully built 7b6aee767fab
Successfully tagged test:latest
Ссылка
https://stackoverflow.com/questions/64804749/docker-build-not-showing-any-output-from-commands