error response from daemon: dr
时间: 2023-04-26 19:02:49 浏览: 117
ocker守护进程出现错误响应:dr。
很抱歉,这个错误信息不够详细,无法确定具体的问题。请提供更多的上下文信息,例如在执行什么操作时出现了这个错误,以及是否有其他错误信息或日志记录。这样才能更好地帮助您解决问题。
相关问题
他为什么会重复输出这种: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
这是因为在循环中,对于每个镜像名,都会进行删除操作。然而,在每次循环时,都会检查所有镜像列表中是否存在对应的镜像,并尝试删除它们。如果某个镜像已经被删除了,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" 的错误信息。如果还有其他问题,请随时告诉我。
报错:针对镜像名 mysql:无需删除镜像,数量未超过3个。 Error response from daemon: No such image: uat:latest Error response from daemon: No such image: uat:latest 针对镜像名 uat:旧的镜像已删除,只保留最近的两个镜像。 针对镜像名 nginx:无需删除镜像,数量未超过3个。 Error response from daemon: No such image: uat:latest Error response from daemon: No such image: uat:latest 针对镜像名 uat:旧的镜像已删除,只保留最近的两个镜像。 针对镜像名 tomcat:无需删除镜像,数量未超过3个。 Error response from daemon: No such image: uat:latest Error response from daemon: No such image: uat:latest 针对镜像名 uat:旧的镜像已删除,只保留最近的两个镜像。 针对镜像名 redis:无需删除镜像,数量未超过3个。 Error response from daemon: No such image: uat:latest Error response from daemon: No such image: uat:latest 针对镜像名 uat:旧的镜像已删除,只保留最近的两个镜像。
这个错误是由于脚本中的筛选逻辑导致的。脚本在筛选镜像时使用了 `grep` 命令,而 `grep` 命令是基于文本行进行匹配的,可能会出现部分匹配的情况。
为了解决这个问题,我们可以使用 `awk` 命令来进行筛选和计数镜像。请尝试以下修改后的脚本:
```bash
#!/bin/bash
# 获取所有镜像列表,并按照创建时间排序
image_list=$(docker image ls --format "{{.Repository}}:{{.Tag}}|{{.CreatedAt}}" | sort -t "|" -k2,2)
# 获取所有镜像名
image_names=$(echo "$image_list" | awk -F ':' '{print $1}' | uniq)
# 遍历每个镜像名
for image_name in $image_names; do
# 获取特定镜像名的镜像列表
filtered_images=$(echo "$image_list" | awk -F ':' -v name="$image_name" '$1 == 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
docker image rm $image
done
echo "针对镜像名 $image_name:旧的镜像已删除,只保留最近的两个镜像。"
else
echo "针对镜像名 $image_name:无需删除镜像,数量未超过3个。"
fi
done
```
这个修改后的脚本使用了 `awk` 命令来提取镜像名,并进行完整匹配。这样可以确保镜像名的准确性,避免了部分匹配的问题。
请再次尝试执行脚本,看看是否能够正常删除旧的镜像并保留最近的两个镜像。如果还有其他问题,请随时告诉我。
阅读全文