Jak wyświetlić i usunąć obraz Docker?
Opublikowany: 2021-08-03Docker to dobrze znana platforma, która umożliwia zarządzanie uruchamianiem i wysyłaniem aplikacji jako kontenerów, które zawierają razem system operacyjny i zależne biblioteki wraz z aplikacją.
Zajmiemy się zarządzaniem obrazami platformy Docker, głównie informując o sposobach wyświetlania listy obrazów platformy Docker i uzyskiwania wymaganych informacji, a następnie opierając się na nauce usuwania jednego lub większej liczby obrazów w efektywny sposób.
Więc zacznijmy.
Wyświetlanie listy obrazów Docker
Aby wyświetlić listę ściągniętych obrazów Dockera, użyj:
abhisheknair@geekflare:~$ docker image ls REPOSITORY TAG IMAGE ID CREATED SIZE redis latest aa4d65e670d6 9 days ago 105MB mysql latest c60d96bd2b77 10 days ago 514MB ubuntu latest c29284518f49 2 weeks ago 72.8MB nginx latest 4cdc5dd7eaad 3 weeks ago 133MB hello-world latest d1165f221234 4 months ago 13.3kB redis 4.0 191c4017dcdd 15 months ago 89.3MB abhisheknair@geekflare:~$
Podobnie jak w przypadku innych poleceń docker
, obsługuje polecenia images
z wieloma opcjami.
$ docker images [OPTIONS] [REPOSITORY[:TAG]]
Jeśli uruchomisz docker images
bez żadnych opcji, wyświetlą się obrazy najwyższego poziomu, takie jak docker image ls
, ich repozytorium i tagi oraz ich rozmiar na dysku.
abhisheknair@geekflare:~$ docker images REPOSITORY TAG IMAGE ID CREATED SIZE mysql latest c60d96bd2b77 10 days ago 514MB ubuntu latest c29284518f49 2 weeks ago 72.8MB nginx latest 4cdc5dd7eaad 3 weeks ago 133MB hello-world latest d1165f221234 4 months ago 13.3kB redis 4.0 191c4017dcdd 15 months ago 89.3MB abhisheknair@geekflare:~$
Te obrazy mają warstwy pośrednie, które zwiększają użyteczność, przyspieszają proces kompilacji i zmniejszają użycie dysku, co nie jest widoczne w powyższym poleceniu. SIZE
to łączna przestrzeń zajmowana przez obraz i wszystkie jego obrazy nadrzędne. Jeśli zapiszesz zawartość obrazu jako plik Tar podczas save
obrazu w oknie dokowanym, będzie on równy podanemu rozmiarowi.
Obraz jest wymieniany wiele razy, jeśli ma wiele nazw lub tagów repozytorium, chociaż pojedynczy obraz zidentyfikowany przez IMAGE ID
używa podanego SIZE
tylko raz.
Lista najnowszych obrazów
abhisheknair@geekflare:~$ docker images REPOSITORY TAG IMAGE ID CREATED SIZE mysql latest c60d96bd2b77 10 days ago 514MB ubuntu latest c29284518f49 2 weeks ago 72.8MB nginx latest 4cdc5dd7eaad 3 weeks ago 133MB hello-world latest d1165f221234 4 months ago 13.3kB redis 4.0 191c4017dcdd 15 months ago 89.3MB abhisheknair@geekflare:~$
Wyświetl listę obrazów według repozytorium i tagu
Aby wyświetlić listę wszystkich obrazów, które należą do konkretnego repozytorium, określ nazwę repozytorium, np.:
abhisheknair@geekflare:~$ docker images redis REPOSITORY TAG IMAGE ID CREATED SIZE redis latest aa4d65e670d6 9 days ago 105MB redis 4.0 191c4017dcdd 15 months ago 89.3MB abhisheknair@geekflare:~$
Możesz dodatkowo określić nazwę repozytorium z tagiem, aby uzyskać bardziej przefiltrowane wyjście:
abhisheknair@geekflare:~$ docker images redis:4.0 REPOSITORY TAG IMAGE ID CREATED SIZE redis 4.0 191c4017dcdd 15 months ago 89.3MB abhisheknair@geekflare:~$
Wyświetl listę identyfikatorów obrazów o pełnej długości
Aby wyświetlić listę wszystkich obrazów bez obcinania IMAGE ID
, użyj:
abhisheknair@geekflare:~$ docker images --no-trunc REPOSITORY TAG IMAGE ID CREATED SIZE redis latest sha256:aa4d65e670d6518e5da96ca9d1a76370a942970a8802e6d5cc6bcf058ab12ca7 9 days ago 105MB mysql latest sha256:c60d96bd2b771a8e3cae776e02e55ae914a6641139d963defeb3c93388f61707 10 days ago 514MB ubuntu latest sha256:c29284518f497b8c5f49933e74e43ca5221e69c8251e780427f7d12f716625ff 2 weeks ago 72.8MB nginx latest sha256:4cdc5dd7eaadff5080649e8d0014f2f8d36d4ddf2eff2fdf577dd13da85c5d2f 3 weeks ago 133MB hello-world latest sha256:d1165f2212346b2bab48cb01c1e39ee8ad1be46b87873d9ca7a4e434980a7726 4 months ago 13.3kB redis 4.0 sha256:191c4017dcdd3370f871a4c6e7e1d55c7d9abed2bebf3005fb3e7d12161262b8 15 months ago 89.3MB abhisheknair@geekflare:~$
Wyświetl listę skrótów obrazów
Obrazy platformy Docker w formacie v2 lub nowszym mają identyfikator umożliwiający adresowanie zawartości, zwany digest
. Aby wyświetlić wartości skrótu obrazu, użyj flagi --digest
jako:
abhisheknair@geekflare:~$ docker images --digests REPOSITORY TAG DIGEST IMAGE ID CREATED SIZE redis latest sha256:cd0c68c5479f2db4b9e2c5fbfdb7a8acb77625322dd5b474578515422d3ddb59 aa4d65e670d6 9 days ago 105MB mysql latest sha256:8b928a5117cf5c2238c7a09cd28c2e801ac98f91c3f8203a8938ae51f14700fd c60d96bd2b77 10 days ago 514MB ubuntu latest sha256:b3e2e47d016c08b3396b5ebe06ab0b711c34e7f37b98c9d37abe794b71cea0a2 c29284518f49 2 weeks ago 72.8MB nginx latest sha256:c5aab9d8e259d54af91e0548abf1fa8188a43079eb86b6ba8df9f482a5380720 4cdc5dd7eaad 3 weeks ago 133MB hello-world latest sha256:df5f5184104426b65967e016ff2ac0bfcd44ad7899ca3bbcf8e44e4461491a9e d1165f221234 4 months ago 13.3kB redis 4.0 sha256:2e03fdd159f4a08d2165ca1c92adde438ae4e3e6b0f74322ce013a78ee81c88d 191c4017dcdd 15 months ago 89.3MB abhisheknair@geekflare:~$
Rejestr 2.0
umożliwia korzystanie z tych skrótów za pomocą poleceń push
, pull
, create
, run
i rmi
. Działa to również z poleceniem FROM
w pliku Dockerfile
.
Filtrowanie danych wyjściowych
Polecenie docker
obsługuje filtrowanie z images
za pomocą flagi --filter
. Obecnie obsługiwane filtry to:
- zwisające (boolean – prawda lub fałsz)
- etykieta (
label=<key>
lublabel=<key>=<value>
) - before (
<image-name>[:<tag>]
,<image id>
or<image@digest>
) – filtruje obrazy utworzone przed podanym id lub referencjami - od (
<image-name>[:<tag>]
,<image id>
lub<image@digest>
) – filtruje obrazy utworzone od podanego id lub referencji - reference (wzorzec referencji obrazu) – filtruje obrazy, których referencja pasuje do określonego wzorca
Co więcej, możesz użyć wielu filtrów, łącząc je, takie jak:
$ docker images --filter "<key1>=<value1>" --filter"<key2>=<value2>"
Przykład:
abhisheknair@geekflare:~$ docker images --filter "before=redis" --filter "since=hello-world" REPOSITORY TAG IMAGE ID CREATED SIZE mysql latest c60d96bd2b77 10 days ago 514MB ubuntu latest c29284518f49 2 weeks ago 72.8MB nginx latest 4cdc5dd7eaad 3 weeks ago 133MB abhisheknair@geekflare:~$
Formatowanie wyjścia
docker images
obsługują formatowanie danych wyjściowych, które mogą być potrzebne do zagnieżdżania z innymi poleceniami, skryptami lub w inny sposób. Oto obsługiwane symbole zastępcze dla flagi --format
:
Symbol zastępczy | Opis |
---|---|
.ID | Identyfikator obrazu |
.Repository | Repozytorium obrazów |
.Tag | Znacznik obrazu |
.Digest | Podsumowanie obrazu |
.CreatedSince | Czas, jaki upłynął od utworzenia obrazu |
.CreatedAt | Czas powstania obrazu |
.Size | Rozmiar dysku obrazu |
Jako przykład, poniższe polecenie drukuje dane wyjściowe bez nagłówków i wyświetla ID
i Repository
oddzielone dwukropkiem ( : ) dla wszystkich obrazów:
abhisheknair@geekflare:~$ docker images --format "{{.ID}}: {{.Repository}}" aa4d65e670d6: redis c60d96bd2b77: mysql c29284518f49: ubuntu 4cdc5dd7eaad: nginx d1165f221234: hello-world 191c4017dcdd: redis abhisheknair@geekflare:~$
Lub, aby wyświetlić listę wszystkich obrazów z ich repozytorium i tagiem w formacie tabeli, możesz użyć:
abhisheknair@geekflare:~$ docker images --format "table {{.ID}}\t{{.Repository}}\t{{.Tag}}" IMAGE ID REPOSITORY TAG aa4d65e670d6 redis latest c60d96bd2b77 mysql latest c29284518f49 ubuntu latest 4cdc5dd7eaad nginx latest d1165f221234 hello-world latest 191c4017dcdd redis 4.0 abhisheknair@geekflare:~$
Usuwanie obrazów Docker
Aby usunąć jeden lub więcej obrazów Dockera z systemu, używamy:

$ docker image rm [OPTIONS] IMAGE [IMAGE...]
Aby usunąć pojedynczy obraz, po prostu określ nazwę obrazu:
abhisheknair@geekflare:~$ docker image rm redis Untagged: redis:latest Untagged: redis@sha256:cd0c68c5479f2db4b9e2c5fbfdb7a8acb77625322dd5b474578515422d3ddb59 Deleted: sha256:aa4d65e670d6518e5da96ca9d1a76370a942970a8802e6d5cc6bcf058ab12ca7 Deleted: sha256:3bd00d38f5ca70200050477c527cc60cfdf82911d6fe03932e2bcae31a95cfa2 Deleted: sha256:22722fde392d188cfbe5bbd0c2451cc71cf5b000afc0e5114c1066bb5e113ec9 Deleted: sha256:38212b55ef525e86cd726cd83c1a82a6009c68d24771d6e93d439fdc88e66f0e Deleted: sha256:188c498579cef37b65a93d6448c6b129fa07d5740fc213a18843ff22d80cd10d Deleted: sha256:2117165cd53c98f13ec7af36c9d8acd239fc541c847efaccb49885decf615d68 abhisheknair@geekflare:~$
Lub, aby usunąć wiele obrazów, określ wiele nazw obrazów oddzielonych spacją:
abhisheknair@geekflare:~$ docker image rm redis mariadb Untagged: redis:latest Untagged: redis@sha256:cd0c68c5479f2db4b9e2c5fbfdb7a8acb77625322dd5b474578515422d3ddb59 Deleted: sha256:aa4d65e670d6518e5da96ca9d1a76370a942970a8802e6d5cc6bcf058ab12ca7 Deleted: sha256:3bd00d38f5ca70200050477c527cc60cfdf82911d6fe03932e2bcae31a95cfa2 Deleted: sha256:22722fde392d188cfbe5bbd0c2451cc71cf5b000afc0e5114c1066bb5e113ec9 Deleted: sha256:38212b55ef525e86cd726cd83c1a82a6009c68d24771d6e93d439fdc88e66f0e Deleted: sha256:188c498579cef37b65a93d6448c6b129fa07d5740fc213a18843ff22d80cd10d Deleted: sha256:2117165cd53c98f13ec7af36c9d8acd239fc541c847efaccb49885decf615d68 Untagged: mariadb:latest Untagged: mariadb@sha256:3b6f9fa1d406e168998d62501b2ee4f27d53138bebfcdac03540758996c5ff1d Deleted: sha256:fd17f57768027456cc17987058474fb21d3c51e9dd764e4497c1dfe92ff058db Deleted: sha256:a638f04e531b032c81a84bda59a36d1df3c4cec62560c403bc2edb642bce79ba Deleted: sha256:af7a7e7bf72e7ad0c5227995f219d9094fafbe0ac973dbe7eb4ab190a5a58ba5 Deleted: sha256:a0cfd81b291e8da6bca0731c9db70fe1b61d176906b1cf05ade1cd61572ffaaa Deleted: sha256:38b00cb5dab64398092fab2b18563af1ef4a9445dec8a531ac725059dc218f41 Deleted: sha256:6e60d29d2d76125f989f503a78729984f7ba3e26bfbf7038d5ab644b8755b7c2 Deleted: sha256:1dafdd60e471b4c1f5244cfe1d20d79f934f504ef42180b637886be2b0b74370 Deleted: sha256:2fffe8e736cdb99359084e297f4bb54a4cac879366bd3e4333d3dbe966f8e9a6 Deleted: sha256:f728037697805db453111266541c202c74971484ef359ea29b9c60064ed9e47e Deleted: sha256:28155a13db3520201db576bf6d56b68fc08ef27b1c4c49dbfeadef523d35c5f0 Deleted: sha256:7555a8182c42c7737a384cfe03a3c7329f646a3bf389c4bcd75379fc85e6c144 abhisheknair@geekflare:~$
Wymuś usunięcie
Mogą być uruchomione kontenery używające obrazów, które próbujesz usunąć. W takich przypadkach Docker wyświetli ostrzeżenie, gdy spróbujesz usunąć obraz, do którego istnieją odnośniki.
abhisheknair@geekflare:~$ docker image rm nginx Error response from daemon: conflict: unable to remove repository reference "nginx" (must force) - container ce908eadf829 is using its referenced image 4cdc5dd7eaad abhisheknair@geekflare:~$
Możesz najpierw zatrzymać skojarzony kontener, a następnie spróbować ponownie lub użyć flagi -f
, która wymusza usunięcie obrazu (bądź ostrożny).
abhisheknair@geekflare:~$ docker image rm nginx -f Untagged: nginx:latest Untagged: nginx@sha256:c5aab9d8e259d54af91e0548abf1fa8188a43079eb86b6ba8df9f482a5380720 Deleted: sha256:4cdc5dd7eaadff5080649e8d0014f2f8d36d4ddf2eff2fdf577dd13da85c5d2f abhisheknair@geekflare:~$
Przycinanie obrazów
Istnieją pewne sytuacje, w których nieużywane obrazy zajmują miejsce na dysku lub wystarczy wyczyścić stare, wiszące obrazy. Takie nieużywane obrazy można wyczyścić za pomocą:
$ docker image prune
Przykład:
abhisheknair@geekflare:~$ docker image prune WARNING! This will remove all dangling images. Are you sure you want to continue? [y/N] y Total reclaimed space: 0B abhisheknair@geekflare:~$
Jeśli chcesz wyczyścić wszystkie obrazy, które nie są również używane przez żadne kontenery, użyj flagi -a
:
abhisheknair@geekflare:~$ docker image prune -a WARNING! This will remove all images without at least one container associated to them. Are you sure you want to continue? [y/N] y Deleted Images: untagged: mariadb:latest untagged: mariadb@sha256:3b6f9fa1d406e168998d62501b2ee4f27d53138bebfcdac03540758996c5ff1d deleted: sha256:fd17f57768027456cc17987058474fb21d3c51e9dd764e4497c1dfe92ff058db deleted: sha256:a638f04e531b032c81a84bda59a36d1df3c4cec62560c403bc2edb642bce79ba deleted: sha256:af7a7e7bf72e7ad0c5227995f219d9094fafbe0ac973dbe7eb4ab190a5a58ba5 deleted: sha256:a0cfd81b291e8da6bca0731c9db70fe1b61d176906b1cf05ade1cd61572ffaaa deleted: sha256:38b00cb5dab64398092fab2b18563af1ef4a9445dec8a531ac725059dc218f41 deleted: sha256:6e60d29d2d76125f989f503a78729984f7ba3e26bfbf7038d5ab644b8755b7c2 deleted: sha256:1dafdd60e471b4c1f5244cfe1d20d79f934f504ef42180b637886be2b0b74370 deleted: sha256:2fffe8e736cdb99359084e297f4bb54a4cac879366bd3e4333d3dbe966f8e9a6 deleted: sha256:f728037697805db453111266541c202c74971484ef359ea29b9c60064ed9e47e deleted: sha256:28155a13db3520201db576bf6d56b68fc08ef27b1c4c49dbfeadef523d35c5f0 deleted: sha256:7555a8182c42c7737a384cfe03a3c7329f646a3bf389c4bcd75379fc85e6c144 untagged: redis:latest untagged: redis@sha256:cd0c68c5479f2db4b9e2c5fbfdb7a8acb77625322dd5b474578515422d3ddb59 deleted: sha256:aa4d65e670d6518e5da96ca9d1a76370a942970a8802e6d5cc6bcf058ab12ca7 deleted: sha256:3bd00d38f5ca70200050477c527cc60cfdf82911d6fe03932e2bcae31a95cfa2 deleted: sha256:22722fde392d188cfbe5bbd0c2451cc71cf5b000afc0e5114c1066bb5e113ec9 deleted: sha256:38212b55ef525e86cd726cd83c1a82a6009c68d24771d6e93d439fdc88e66f0e deleted: sha256:188c498579cef37b65a93d6448c6b129fa07d5740fc213a18843ff22d80cd10d deleted: sha256:2117165cd53c98f13ec7af36c9d8acd239fc541c847efaccb49885decf615d68 Total reclaimed space: 445.2MB abhisheknair@geekflare:~$
Można również użyć flagi --force
lub -f
, aby kontynuować czyszczenie bez potwierdzenia, lub flagi --filter
, aby podać wartości filtra (np. 'until=<znacznik czasu>') do polecenia prune
.
Przykład:
$ docker image prune -a --force --filter "until=2021-01-04T00:00:00"
Lub
$ docker image prune --filter="label=deprecated"
Korzystanie z polecenia rmi
Możesz również użyć polecenia rmi
z dockerem, aby usunąć obrazy.
Usuwa (i usuwa tagi) jeden lub więcej obrazów z węzła Docker. Jeśli obraz ma wiele tagów, użycie tego polecenia z tagiem jako parametrem usuwa tylko tag. Jeśli tag jest jedynym dla obrazu, zarówno obraz, jak i tag są usuwane.
To polecenie nie usuwa obrazów z rejestru. Ponadto nie można usunąć obrazu działającego kontenera, chyba że użyjesz opcji -f
, tak jak w przypadku polecenia docker image rm
.
Przykład:
abhisheknair@geekflare:~$ docker rmi alpine Untagged: alpine:latest Untagged: alpine@sha256:adab3844f497ab9171f070d4cae4114b5aec565ac772e2f2579405b78be67c96 Deleted: sha256:d4ff818577bc193b309b355b02ebc9220427090057b54a59e73b79bdfe139b83 Deleted: sha256:72e830a4dff5f0d5225cdc0a320e85ab1ce06ea5673acfe8d83a7645cbd0e9cf abhisheknair@geekflare:~$
Możesz także użyć --no-prune
, aby określić, że rodzice nie są usuwani.
Zatrzymaj kontener i usuń obrazy
W wielu przypadkach może być konieczne zatrzymanie wszystkich kontenerów i usunięcie wszystkich powiązanych obrazów. Możesz to zrobić po prostu za pomocą:
$ docker rm -vf $(docker ps -a -q)
Powyższe polecenie zatrzyma i usunie wszystkie działające kontenery na siłę. Następnie możemy przystąpić do usuwania połączonych obrazów za pomocą:
$ docker rmi -f $(docker images -a -q)
Streszczenie
Docker to wszechstronne narzędzie, które jest istotną częścią dzisiejszego arsenału inżynierów DevOps i jest częścią innych dynamicznych technologii, takich jak Kubernetes. Zarządzanie obrazami platformy Docker jest jedną z podstawowych części zarządzania wdrożeniem platformy Docker i rozwiązywania problemów.
Powinieneś teraz mieć podstawowe pojęcie o możliwościach, jakie oferuje docker
CLI z poleceniami takimi jak image
, images
i rmi
. Ich flagi oferują dalsze dostosowywanie i oferują zaawansowane opcje filtrowania i dostosowywania, które mogą pomóc w automatyzacji i zaawansowanym użytkowaniu.
Skorzystaj z docker [COMMAND] help
uzyskać więcej informacji na temat dostępnych opcji i powiązanych tematów pomocy.