AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1043707
Accepted
Mangosniper
Mangosniper
Asked: 2020-11-25 02:30:14 +0800 CST2020-11-25 02:30:14 +0800 CST 2020-11-25 02:30:14 +0800 CST

在多个注册表上托管 docker 映像,但以相同的方式引用它们,例如在 k8s 部署中

  • 772

自从我开始使用 docker 之后,我就有一个问题,到目前为止我还没有得到一个好的答案。

假设我有一个指定 k8s 部署的 .yaml 文件。我们正在本地构建服务器上构建我们的 docker 镜像,它们被推送到本地注册表,例如 registry.mycompany.com,它只能在我们本地公司网络中访问。因此,在我的 .yaml 中,我将使用“image:registry.mycompany.com/myrepo/myimage:1.0”引用该图像。

现在,当我在本地 k8s 集群上部署它时,它可以正常工作,因为域名得到解析并且可以拉取图像。现在我想在任何云中部署相同的内容。好吧,它不会工作,因为注册表不可用。如果我想在我的一个客户位置部署相同的 .yaml 也是如此,他们也有充分的理由无法访问我的本地注册表。

这种事情一般是怎么解决的?现在,我在我的客户或云帐户中设置另一个注册表,重新标记我的所有图像并将它们推送到该注册表,并且当我在客户位置或云中部署时更改 .yamls 中的所有图像引用。因此,必须维护大量 99% 相同的文件集。那不是它应该如何工作吗?

我的“愿望”是我可以只指定图像名称和标签“myimage:1.0”,如果他能找到图像并拉取它,k8s 集群只会检查所有可用的注册表。但我也知道没有“知名注册表列表”,您可以在映像名称中指定注册表或将其省略,然后将查询 docker hub。但是,如果我可以指定只是

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: MyDeployment
spec:
  replicas: 1
  template:
    metadata:
      labels:
        app: myimage
    spec:
      containers:
        - name: myimage
          image: 'myimage:1.0'
          ports: []

和注册表列表:

registries:
    - registry.mycompany.com
    - registry.cloud.com
    - registry.localcustomer.com

但没有那样的事,对吧?

我能想到的唯一其他解决方案是将所有内容构建到 helm 图表中,使图像的第一部分引用一个变量并将注册表作为变量传递给图表。

欢迎任何想法和信息。提前致谢 :)

docker-registry docker kubernetes helm
  • 1 1 个回答
  • 557 Views

1 个回答

  • Voted
  1. Best Answer
    Dawid Kruk
    2020-11-26T04:29:45+08:002020-11-26T04:29:45+08:00

    有一些解决方法可以达到您在问题中描述的结果:

    • 头盔图
    • 自定义
    • 登记处

    头盔图

    正如你在问题中所说:

    我能想到的唯一其他解决方案是将所有内容构建到 helm 图表中,使图像的第一部分引用一个变量并将注册表作为变量传递给图表。

    从主观上讲,这是为Deployment.

    它的示例可能如下所示:

    deployment.yaml:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: ubuntu
    spec:
      selector:
        matchLabels:
          app: ubuntu
      replicas: 1
      template:
        metadata:
          labels:
            app: ubuntu
        spec:
          containers:
          - name: "{{ .Values.image.repo }}{{ .Values.image.name }}:{{ .Values.image.tag }}"  
            image: 
            command:
            - sleep 
            - "infinity"
    

    a 中的值template可以通过以下方式提供:

    • values.yaml文件:
    image: 
      repo: gcr.io/ # <-- only an example
      name: ubuntu
      tag: latest
    
    • $ helm命令如:

    $ helm install ubuntu . --set=image.repo=eu.gcr.io/

    小费!

    指定--set具有现有值的参数values.yaml将覆盖它(在此示例中)!


    自定义

    您还可以使用它们各自的存储库和图像kustomize来“渲染” 。Deployment

    在下面的博客文章中有关于如何完成的相当广泛的解释:

    • Blog.stack-labs.com:代码:Kustomize 101

    这种解决方案的示例(通过以下链接)可以归结为:

    deployment.yaml

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: sl-demo-app
    spec:
      selector:
        matchLabels:
          app: sl-demo-app
      template:
        metadata:
          labels:
            app: sl-demo-app
        spec:
          containers:
          - name: app
            image: foo/bar:latest
            ports:
            - name: http
              containerPort: 8080
              protocol: TCP
    

    custom-image.yaml

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: sl-demo-app
    spec:
      template:
        spec:
          containers:
            - name: app # IMPORTANT 
              image: eu.gcr.io/ubuntu:latest
    

    kustomization.yaml

    apiVersion: kustomize.config.k8s.io/v1beta1
    kind: Kustomization
    
    resources:
      - deployment.yaml
    
    patchesStrategicMerge:
    - custom-image.yaml
    

    运行上述示例后:

    • kustomize build

    您应该看到图像的变化:

    • 从:image: foo/bar:latest
    • 至:image: eu.gcr.io/ubuntu:latest

    您还可以查看此 StackOverflow 答案:

    • Stackoverflow.com:问题:Kustomize 将 imagepullsecrets 添加到所有部署

    登记处

    您还可以查看注册表项目,例如Harbor。

    你可以在他们的 github 页面上阅读:

    Harbor 是一个开源可信的云原生注册表项目,用于存储、签名和扫描内容。Harbor 通过添加用户通常需要的功能(例如安全性、身份和管理)来扩展开源 Docker Distribution。

    特征

    • 云原生注册中心:Harbor 支持容器镜像和 Helm 图表,可作为云原生环境(如容器运行时和编排平台)的注册中心。

    • 基于角色的访问控制:用户通过“项目”访问不同的存储库,并且用户可以对项目下的图像或 Helm 图表具有不同的权限。

    • 基于策略的复制:可以使用过滤器(存储库、标签和标签)基于策略在多个注册表实例之间复制(同步)图像和图表。如果遇到任何错误,Harbor 会自动重试复制。这可用于辅助负载平衡、实现高可用性并促进混合和多云场景中的多数据中心部署。

    ...

    -- Github.com:Goharbor:港口

    有了它,您可以:

    • 创建只能由经过身份验证和授权的帐户使用的存储库。
    • 将其用于位置之间的复制目的。

    除此之外,您还可以查看 Docker Registry 代理,如下所示:

    • Hub.docker.com:Rpardini:Docker 注册表代理

    其他资源:

    • Helm.sh
    • Github.com:Kubernetes 签名:Kustomize
    • 2

相关问题

  • 私有 Docker Registry(带有 TLS 证书)

  • 为什么 docker 使用 nginx SSL 反向代理从私有 Docker 注册表中拉取在注册表主机上工作,而不是在远程主机上工作?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve