Za każdym razem, gdy doker wykonuje RUN
polecenie z pliku Docker, zatwierdzana jest nowa warstwa w systemie plików obrazu . Dogodnie możesz użyć tych identyfikatorów warstw jako obrazów, aby rozpocząć nowy kontener.
Weź następujący plik Dockerfile:
FROM busybox
RUN echo 'foo' > /tmp/foo.txt
RUN echo 'bar' >> /tmp/foo.txt
i zbuduj to:
$ 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
Teraz można rozpocząć nowy pojemnik z 00f017a8c2a6
, 044e1532c690
i 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
oczywiście możesz chcieć uruchomić powłokę w celu eksploracji systemu plików i wypróbowania poleceń:
$ 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
Gdy jedno z poleceń Dockerfile nie powiedzie się, musisz poszukać identyfikatora poprzedniej warstwy i uruchomić powłokę w kontenerze utworzonym z tego identyfikatora:
docker run --rm -it <id_last_working_layer> bash -il
Raz w pojemniku:
- spróbuj wykonać polecenie, które się nie powiodło, i odtwórz problem
- następnie napraw polecenie i przetestuj je
- na koniec zaktualizuj plik Docker za pomocą stałego polecenia
Jeśli naprawdę musisz eksperymentować na rzeczywistej warstwie, która nie powiodła się, zamiast pracować z ostatnią warstwą roboczą, zobacz odpowiedź Drew .
/var/lib/docker/aufs/diff/3afa404e[...]/.cpanm
tych są wnętrzności Dockera i nie chciałbym z nimi zadzierać