将Docker镜像从Gitlab的私有Docker注册表部署到Openshift

时间:2017-03-21 15:38:12

标签: docker openshift gitlab kubernetes

我正在开发基于Docker的项目。项目代码托管在私有Gitlab安装git.example.com中。有了它,部署了Docker private registry shipped with Gitlabregistry.example.com

该项目有一个CI设置,最终构建Docker镜像并推送到注册表,这部分按预期工作。作为Gitlab+Docker registry does not yet support multiple images related to the same Git repo,我使用标记解决方法将图像指定为:

  • registry.example.com/group/my.project:web
  • registry.example.com/group/my.project:app

我创建了一个用户并将其附加到项目中,通过本地登录并尝试提取上面的图像,这可以按预期工作。

我已将ImageStream块添加为:

apiVersion: v1
kind: ImageStream
metadata:
    name: web
spec:
    tags:
    -
        from:
            kind: DockerImage
            name: registry.example.com/group/my.project:web
        name: latest

这会在图像部分添加图像,但它无法拉动它Openshift还无法访问Docker Registry。我按照here描述添加了一个新的Docker机密,现在我可以在Openshift中看到图像元数据,一切看起来都符合预期。

但是,如果我添加部署配置,就像这样:

apiVersion: v1
kind: DeploymentConfig
metadata:
    creationTimestamp: null
    labels:
        service: web
    name: web
spec:
    replicas: 1
    selector:
        service: web
    strategy:
        resources: {  }
    template:
        metadata:
            creationTimestamp: null
            labels:
                service: web
        spec:
            containers:
                -
                    name: web
                    ports:
                        -
                            containerPort: 80
                    resources: {  }
            restartPolicy: Always
    test: false
    triggers:
        -
            type: ConfigChange
        -
            type: ImageChange
            imageChangeParams:
                automatic: true
                containerNames:
                    - web
                from:
                    kind: ImageStreamTag
                    name: 'web:latest'
status: {  }

我一直收到错误:

Failed to pull image "registry.example.com/group/my.project@sha256:3333022641e571d7e4dcae2953d35be8cdf9416b13967b99537c4e8f150f74e4": manifest unknown: manifest unknown

在已创建的窗格的“事件”选项卡中。这基本上杀死了我将预建图像部署到Openshift的计划。

我知道Docker 1.9 - > 1.10不兼容,但这是Openshift 1.4.1,用Docker 1.13推送图像所以它不应该是一个问题。

我如何开始调试这个,有没有办法访问任何类型的日志,这可以解释发生了什么?为什么ImageStream能够找到它需要的一切(并访问我的注册表),而不是DeploymentConfig?

1 个答案:

答案 0 :(得分:0)

回答我自己的问题:似乎Docker的发行版(注册表守护程序)有a bug which manifests itself in quite a weird way

基本上,问题是:

  1. 注册表位于Apache反向代理
  2. 之后
  3. 图像构建并从CI运行器推送到Gitlab的注册表,摘要SHA:1234(当然是示例)
  4. 图像被导入到Openshift,它查询元数据和Docker Distribution声称摘要是SHA:ABCD,你可以通过推送然后立即拉动来重现这个,摘要应该是相同的两次,如在链接中解释
  5. 当Openshift尝试实际拉动图像时,它会在上面出现可怕的“Manifest unknown”错误(因为它试图使用无效的摘要获取图像,而不是自己的错误)
  6. 所有症状看起来与Docker v1 =>完全一样Docker v2 API更改,除了完全不同的原因
  7. 我已经将我的Gitlab实例移动到另一台机器(它在Nginx后面)并且它没有问题。