我在努力
docker rmi c565603bc87f
错误:
来自守护进程的错误响应:冲突:无法删除c565603bc87f
(不能强制)- image有依赖的子映像
所以我不能用-f标记删除image。如何删除图像,然后所有的孩子?
Linux和docker版本:
uname -
Linux goracio-pc 4.4.0-24-generic #43-Ubuntu SMP Wed Jun 8 19:27:37 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux
码头工人版本
客户:
版本:1.11.2
API版本:1.23
Go版本:go1.5.4
Git提交:b9f10c9
建成:2016年6月1日星期三22:00:43
OS /拱:linux / amd64
服务器:
版本:1.11.2
API版本:1.23
Go版本:go1.5.4
Git提交:b9f10c9
建成:2016年6月1日星期三22:00:43
OS /拱:linux / amd64
我有这个问题,这里没有一个简短的答案,即使在上面@tudor提到的页面。我想在这里分享一下我是如何摆脱这些图像的。我想出了一个想法,从属图像必须是>=父图像的大小,这有助于识别它,以便我们可以删除它。
我按大小列出了这些图片,看看是否能发现其中的相关性:
docker images --format '{{.Size}}\t{{.Repository}}\t{{.Tag}}\t{{.ID}}' | sort -h -r | column -t
它所做的是使用docker中的一些特殊格式来首先定位图像大小列,然后以相反的顺序运行人类可读的排序。然后恢复易于阅读的列。
然后我查看<none>容器,并将列表中的第一个容器与类似的大小匹配。我在该图像上执行了一个简单的docker rmi <image:tag>,所有<none>子图像都随它而去。
所有子映像的问题映像实际上是我第一次开始使用docker时使用的该死的myrepo/getstart -lab映像。这是因为我从第一个创建链的测试图像中创建了一个新图像。
希望这能在某种程度上帮助到其他人。
当我想删除一些未使用的图像名称“<none>”在docker中,我面临的问题是无法删除a354bbc7c9b7(不能强制)-图像有依赖的子图像。为了解决这个问题:
Sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
01ee1276bbe0 lizard:1 "/bin/sh -c 'java ..." About an hour ago Exited (1) About an hour ago objective_lewin
49d73d8fb023 javaapp:latest "/usr/bin/java -ja..." 19 hours ago Up 19 hours 0.0.0.0:8091->8091/tcp pedantic_bell
405fd452c788 javaapp:latest "/usr/bin/java -ja..." 19 hours ago Created infallible_varahamihira
532257a8b705 javaapp:latest "/usr/bin/java -ja..." 19 hours ago Created demo-default
9807158b3fd5 javaapp:latest "/usr/bin/java -ja..." 19 hours ago Created xenodochial_kilby
474930241afa jenkins "/bin/tini -- /usr..." 13 days ago Up 4 days 0.0.0.0:8080->8080/tcp, 0.0.0.0:50000->50000/tcp myjenkins
563d8c34682f mysql/mysql-server:latest "/entrypoint.sh my..." 3 weeks ago Up 4 days (healthy) 0.0.0.0:3306->3306/tcp, 33060/tcp mymysql
b4ca73d45d20 phpmyadmin/phpmyadmin "/run.sh phpmyadmin" 4 weeks ago Exited (0) 3 weeks ago phpmyadmin
你可以看到我有几个图像与名称javaapp:最新和不同的容器名称。因此,我杀死并删除了“javaapp:latest”容器的所有容器:
sudo docker stop containerName
sudo docker rm“containrName”
Then
sudo docker rmi -f "imageId"
所以我可以删除所有的图像名称“<none>”
古德勒克
假设我们有一个Dockerfile
FROM ubuntu:trusty
CMD ping localhost
我们在没有TAG或命名的情况下构建图像
docker build .
现在我们有一个成功报告“成功构建57ca5ce94d04”
如果我们看到docker图像
REPOSITORY TAG IMAGE ID CREATED SIZE
<none> <none> 57ca5ce94d04 18 seconds ago 188MB
ubuntu trusty 8789038981bc 11 days ago 188MB
我们需要先移除
Docker rmi 57ca5ce94d04
紧随其后的是
docker rmi 8789038981bc
由该图像将被删除!
某人建议的强制迁移
docker rmi $(docker images -q) -f
对我来说有用的是使用REPOSITORY:TAG组合而不是IMAGE ID。
当我试图用命令docker rmi < image ID>删除一个没有与此映像关联的容器的docker映像时,我得到了这样的消息:
$ docker rmi 3f66bec2c6bf
Error response from daemon: conflict: unable to delete 3f66bec2c6bf (cannot be forced) - image has dependent child images
当我使用命令docker rmi RPOSITORY:TAG时,我可以成功删除
$ docker rmi ubuntu:18.04v1
Untagged: ubuntu:18.04v1
图像层:存储库通常被称为图像或容器图像,但实际上它们由一个或多个层组成。存储库中的映像层以父子关系连接在一起。每个图像层表示自己和父层之间的变化。
docker构建模式使用继承。这意味着版本i依赖于版本i-1。因此,我们必须删除版本i+1才能删除版本i。这是一个简单的依赖关系。
如果你想删除所有图像,除了最后一个(最新的)和第一个(基础),然后我们可以导出最后一个(最新的一个)使用docker保存命令如下所示。
docker save -o <output_file> <your_image-id> | gzip <output_file>.tgz
然后,现在,使用image-id删除所有图像,如下所示。
docker rm -f <image-id i> | docker rm -f <image i-1> | docker rm -f <image-id i-2> ... <docker rm -f <image-id i-k> # where i-k = 1
现在,如下所示加载您保存的tgz图像。
gzip -c <output_file.tgz> | docker load
使用docker ps -q查看加载图像的image-id。它没有标签和名字。您可以简单地更新标签和名称,如下所示。
docker tag <image_id> group_name/name:tag
扩展@Nguyen提供的答案-这个函数可以添加到你的.bashrc等,然后从命令行调用,以帮助清理任何有依赖子图像的图像错误…
您可以自己运行该函数,如果docker ps失败,那么它将使用sudo运行docker命令并提示您输入密码。
不会删除任何正在运行的容器的映像!
docker_rmi_dependants ()
{
DOCKER=docker
[ docker ps >/dev/null 2>&1 ] || DOCKER="sudo docker"
echo "Docker: ${DOCKER}"
for n in $(${DOCKER} images | awk '$2 == "<none>" {print $3}');
do
echo "ImageID: $n";
${DOCKER} inspect --format='{{.Id}} {{.Parent}}' $(${DOCKER} images --filter since=$n -q);
done;
${DOCKER} rmi $(${DOCKER} images | awk '$2 == "<none>" {print $3}')
}
我的.bashrc文件中也有这个…
docker_rm_dangling ()
{
DOCKER=docker
[ docker ps >/dev/null 2>&1 ] || DOCKER="sudo docker"
echo "Docker: ${DOCKER}"
${DOCKER} images -f dangling=true 2>&1 > /dev/null && YES=$?;
if [ $YES -eq 1 ]; then
read -t 30 -p "Press ENTER to remove, or CTRL-C to quit.";
${DOCKER} rmi $(${DOCKER} images -f dangling=true -q);
else
echo "Nothing to do... all groovy!";
fi
}
适用于:
$ docker --version
Docker version 17.05.0-ce, build 89658be
正如这里所解释的,我使用以下方法来识别依赖图像并删除它们,
image_id=123456789012
docker images -a -q --filter since=$image_id |
xargs docker inspect --format='{{.Id}} {{.Parent}}'
你会看到类似这样的输出:
sha256:f7ef19862215ec0bf7a6b103504d213e1c001691703808f4154689cfbb5f14f9 sha256:a7d2efad2847bd10e5223980ed80f5781c716eddbf6131a3cf97614e7f2db97f
sha256:03690ae141346203959d0ae1b3e8d34b7a4232095d774af57dda6282fce99cc4 sha256:5713074659bb5352496ea680a903eba2f66e0495538c9db37336f4ba92994ea8
sha256:311f587811942d328edc52e5953d794eb9b81fe392512080d9fc1d350a6b2024 sha256:aa674f7f2621946db257720c378377b8714739d20879542d875b84c53b59bc75
然后你可以逐个删除这些图片,如下所示:
docker image rm f7ef19862215ec0bf7a6b103504d213e1c001691703808f4154689cfbb5f14f9
输出类似如下所示的内容:
Untagged: prathap/cognitive_robotics_gpu:v1
Untagged: prathap/cognitive_robotics_gpu@sha256:db6e7543a13e9a96241c985b9b3145b8fd65effb68c183301385b495875f1a5a
Deleted: sha256:03690ae141346203959d0ae1b3e8d34b7a4232095d774af57dda6282fce99cc4
Deleted: sha256:263f655670436758f8e3f23f31170083fc8d60c4eebe01a5b3fda1e73bed3ad1