他为什么会重复输出这种:Untagged: uat:041315a16183 已删除镜像 uat:041315a16183 Untagged: uat:021283c8eb95 已删除镜像 uat:021283c8eb95 Error response from daemon: No such image: uat:041315a16183 已删除镜像 uat:041315a16183 Error response from daemon: No such image: uat:021283c8eb95 已删除镜像 uat:021283c8eb95 Error response from daemon: No such image: uat:041315a16183 已删除镜像 uat:041315a16183 Error response from daemon: No such image: uat:021283c8eb95 已删除镜像 uat:021283c8eb95 Error response from daemon: No such image: uat:041315a16183 已删除镜像 uat:041315a16183 Error response from daemon: No such image: uat:021283c8eb95 已删除镜像 uat:021283c8eb95
时间: 2024-04-15 17:31:09 浏览: 150
这是因为在循环中,对于每个镜像名,都会进行删除操作。然而,在每次循环时,都会检查所有镜像列表中是否存在对应的镜像,并尝试删除它们。如果某个镜像已经被删除了,Docker引擎会返回 "No such image" 的错误信息。
为了解决这个问题,可以在删除镜像之前,先检查该镜像是否存在。如果镜像不存在,则跳过删除操作。以下是修改后的脚本:
```bash
#!/bin/bash
# 获取所有镜像列表,并按照创建时间排序
image_list=$(docker image ls --format "{{.Repository}}:{{.Tag}}|{{.CreatedAt}}" | sort -t "|" -k2,2)
# 获取所有镜像名
image_names=$(echo "$image_list" | cut -d "|" -f 1 | uniq)
# 遍历每个镜像名
for image_name in $image_names; do
# 获取特定镜像名的镜像列表
filtered_images=$(echo "$image_list" | grep "$image_name")
# 获取镜像数量
image_count=$(echo "$filtered_images" | wc -l)
# 如果镜像数量超过3个,则删除旧的镜像,只保留最近的两个
if [ $image_count -gt 3 ]; then
images_to_delete=$((image_count - 2))
images_to_delete_list=$(echo "$filtered_images" | head -n $images_to_delete | cut -d "|" -f 1)
for image in $images_to_delete_list; do
# 检查镜像是否存在,再进行删除操作
if docker image inspect $image >/dev/null 2>&1; then
docker image rm $image
echo "已删除镜像 $image"
else
echo "镜像 $image 不存在,跳过删除操作"
fi
done
fi
done
```
这个修改后的脚本在删除镜像之前会先使用 `docker image inspect` 命令检查镜像是否存在。如果镜像存在,则进行删除操作,并输出相应的信息。如果镜像不存在,则跳过删除操作,并输出相应的信息。
请再次尝试执行脚本,看看是否能够正常删除旧的镜像并保留最近的两个镜像,同时避免重复输出 "No such image" 的错误信息。如果还有其他问题,请随时告诉我。
阅读全文