docker buildx 构建多平台镜像错误x509: certificate signed by unknown authority

异常分析

buildx 构建时,如果去公司内部的仓库拉取镜像时,会遇到下面的这种授权不通过问题

x509: certificate signed by unknown authority

这是因为buildx构建时在单独的容器环境里面执行的,如果我们只在宿主机配置了crt安全证书是不够的,我们还得把这个证书更新buildx的容器里面才可以,方法如下:

获取私仓证书

echo -n | openssl s_client -showcerts -connect harbor.my.com:443 2>/dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' >> ./my_harbor.crt

添加到MAC系统

sudo security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain ./my_harbor.crt

添加到BuildKitd容器中

BUILDER=$(docker ps | grep buildkitd  | awk '{print $1}')
docker cp ./my_harbor.crt $BUILDER:/usr/local/share/ca-certificates/ 
sudo docker exec $BUILDER update-ca-certificates
sudo docker restart $BUILDER 

再次构建

docker buildx build --platform=linux/amd64 --load -t  chaosblade:1 -f myDockerfile .

参考链接

使用buildx构建多平台镜像 - jinnzy 的博客

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值