docker版本v23.0后,构建Dockerfile中FROM私库镜像报错构建失败、删除无用镜像

问题:

Docker版本在v23.0以后,只要Dockerfile中FROM的私库镜像不存在本地,不会使用http,会使用https协议,就会报错:

# 我本地是v24.0.2版本Docker
[root@localhost ipd]# docker build . -t zhubayi.xxx.com.cn/test/bap:2.7.1
[+] Building 0.6s (3/3) FINISHED                                                                                                                                                                       docker:default
 => [internal] load build definition from Dockerfile                                                                                                                                                             0.2s
 => => transferring dockerfile: 1.05kB                                                                                                                                                                           0.0s
 => [internal] load .dockerignore                                                                                                                                                                                0.2s
 => => transferring context: 2B                                                                                                                                                                                  0.0s
 => ERROR [internal] load metadata for harbor.xxx.com.cn/xxx/tomcat:8.5.90-jdk8-temurin                                                                                                                      0.0s
------
 > [internal] load metadata for harbor.xxx.com.cn/xxx/tomcat:8.5.90-jdk8-temurin:
------
Dockerfile:2
--------------------
   1 |     #指定基础镜像
   2 | >>> FROM zhubayi.xxx.com.cn/xxx/tomcat:8.5.90-jdk8-temurin
   3 |     #指定环境变量,时区
   4 |     ENV TZ=Asia/Shanghai
--------------------
ERROR: failed to solve: harbor.xxx.com.cn/xxx/tomcat:8.5.90-jdk8-temurin: failed to do request: Head "https://zhubayi.xxx.com.cn/v2/xxx/tomcat/manifests/8.5.90-jdk8-temurin": tls: failed to verify certificate: x509: certificate signed by unknown authority

但我已经在 /etc/docker/daemon.json 中正确配置了 insecure-registries了,即能 pull 也能 push

问题原因

Docker在v23.0版本及以后,使用了build-kit代替了旧的实现,目前build-kitinsecure-registries配置可能没做兼容,构建Dockerfile FROM镜像时未判断是私库,导致报错。

查看docker版本

docker -v

处理方式

目前(2023.07.21)办法就一个,在 ~/.bashrc/etc/profile 添加一行 export DOCKER_BUILDKIT=0,然后 source 一个修改的配置文件。

命令示例:

echo "export DOCKER_BUILDKIT=0" >> ~/.bashrc
source ~/.bashrc

或者

source /etc/profile

docker命令之删除无用镜像

删除无用镜像(需要收到输入y)

docker image prune -a

强制删除镜像

docker image prune -a -f 

删除异常停止的docker容器

docker rm `docker ps -a | grep Exited | awk '{print $1}'`

删除名称或标签为none的镜像

docker rmi -f  `docker images | grep '<none>' | awk '{print $3}'`
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值