记在解决GitLab-CI下的Docker编译推送问题后

问题描述

最近一直在测试GitLab下的Runner,并在其下实现CI,其中遇到Docker Image编译后推送到Gitlab的容器中心失败的问题.

在容器内执行完Docker镜像的编译后,自动推送到注册中心时,报如下错误:

c2bf021f0c8d: Layer already exists
cd7100a72410: Layer already exists
dcf1253999b2: Pushed
a7e843cd55f6: Pushed
4fef4efdeb56: Pushed
unauthorized: authentication required
ERROR: Job failed: exit code 1

解决问题

问题排查

  • 最初因为另一项目,有过成功的例子,所以一直将问题聚焦在Dockerfile上,可是后来本地编译成功,并且推送成功。

  • 不得不讲目标转移到gitlab-ci.yml的内容上;一步步调试,编译都没问题,一直都是最后Push时出现问题。

  • 根据提示是unauthorized认证问题,部分资料显示是前置行文的docker login有问题,在将cat ~/.docker/config.json文件打印调试后,发现问题也不在登陆上。

  • 接着排查,又有资料显示是nginx转发注册中心端口时的问题,提到http和https的问题:指登陆时走https,而推送镜像时走http。为此,又将gitlab重新配置了一番,幸好我是采用docker-compose的方式搭建的,否则太麻烦了。

  • 为了解决问题,我是换了各种关键词,百度谷歌无所不用。最后终于找到靠谱的问题记录,说是认证问题是由于授权Token失效的问题,因为官方推荐在CI中使用环境变量的方式登录,并推荐:"$CI_REGISTRY_USER" 和 "$CI_REGISTRY_PASSWORD"

问题解决

通过下面的操作路径,将容器注册中心的授权有效期改为50即可

admin >> application_settings >> Container Registry

unauthorized: authentication required on docker push to a different repo

相关链接

转载于:https://my.oschina.net/dingdayu/blog/1809811

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值