Кожен раз, коли докер успішно виконує RUN
команду з Dockerfile, здійснюється новий шар у файловій системі зображень . Зручно ви можете використовувати ці ідентифікатори шарів як зображення для запуску нового контейнера.
Візьміть такий Dockerfile:
FROM busybox
RUN echo 'foo' > /tmp/foo.txt
RUN echo 'bar' >> /tmp/foo.txt
і побудувати його:
$ docker build -t so-2622957 .
Sending build context to Docker daemon 47.62 kB
Step 1/3 : FROM busybox
---> 00f017a8c2a6
Step 2/3 : RUN echo 'foo' > /tmp/foo.txt
---> Running in 4dbd01ebf27f
---> 044e1532c690
Removing intermediate container 4dbd01ebf27f
Step 3/3 : RUN echo 'bar' >> /tmp/foo.txt
---> Running in 74d81cb9d2b1
---> 5bd8172529c1
Removing intermediate container 74d81cb9d2b1
Successfully built 5bd8172529c1
Тепер ви можете створити новий контейнер з 00f017a8c2a6
, 044e1532c690
і 5bd8172529c1
:
$ docker run --rm 00f017a8c2a6 cat /tmp/foo.txt
cat: /tmp/foo.txt: No such file or directory
$ docker run --rm 044e1532c690 cat /tmp/foo.txt
foo
$ docker run --rm 5bd8172529c1 cat /tmp/foo.txt
foo
bar
звичайно, ви можете запустити оболонку для вивчення файлової системи та спробувати команди:
$ docker run --rm -it 044e1532c690 sh
/ # ls -l /tmp
total 4
-rw-r--r-- 1 root root 4 Mar 9 19:09 foo.txt
/ # cat /tmp/foo.txt
foo
Коли одна з команд Dockerfile виходить з ладу, вам потрібно зробити пошук ідентифікатора попереднього шару і запустити оболонку в контейнер, створений з цього ідентифікатора:
docker run --rm -it <id_last_working_layer> bash -il
Потрапивши в контейнер:
- спробуйте команду, яка не вдалася, і відтворіть проблему
- потім виправте команду і протестуйте її
- нарешті оновіть свій Dockerfile за допомогою фіксованої команди
Якщо вам дійсно потрібно експериментувати на фактичному шарі, який не вдався замість того, щоб працювати з останнього робочого шару, дивіться відповідь Дрю .
/var/lib/docker/aufs/diff/3afa404e[...]/.cpanm
це - внутрішні документи Докера, і я б не