下载k8s.gcr.io仓库的镜像的两个方式

简介: 下载k8s.gcr.io仓库的镜像的两个方式

 

在一些k8s环境,服务器没有直接访问k8s.gcr.io、gcr.io仓库的权限,这就需要docker命令能使用代理。

方式1: Docker代理

如果你已经在本地windows上使用 v2ray的服务器 的工具,默认可以通过它的10809端口来拉取镜像。在安装docker的linux服务器执行以下操作,其中10.0.159.222是你本地windows能上网的网卡IP:

注意还要在客户端里鼠标右键勾选允许其他设备连接。以上配置完成后即可直接拉取google镜像

# 为docker服务创建一个内嵌的systemd目录

mkdir -p /etc/systemd/system/docker.service.d


# 设置代理

cat > /etc/systemd/system/docker.service.d/http-proxy.conf  <<EOF

[Service]

Environment="HTTP_PROXY=http://10.0.159.222:10809"

Environment="NO_PROXY=localhost,127.0.0.1,docker-registry.example.com,.corp"

EOF


# 更新配置& 重启Docker服务

systemctl daemon-reload && systemctl restart docker


#确认设置已生效

[root@master-1 ~]# systemctl show --property=Environment docker

Environment=HTTP_PROXY=http://10.0.159.222:10809 NO_PROXY=localhost,127.0.0.1,https://uy35zvn6.mirror.aliyuncs.com

NO_PROXY

如果你有内部 Docker registries需要联系而无需代理,你可以通过NO_PROXY环境变量指定它们。

NO_PROXY变量指定一个字符串,其中包含应从代理中排除的主机的逗号分隔值。这些是你可以指定以排除主机的选项:

    • IP 地址前缀 ( 1.2.3.4)
    • 域名,或特殊的 DNS 标签 ( *)
    • 域名与该名称和所有子域相匹配。以“.”开头的域名 仅匹配子域。例如,给定域 foo.example.comexample.com
      • example.com匹配example.comfoo.example.com
      • .example.com 只匹配 foo.example.com
        • 单个星号 ( *) 表示不应进行代理
        • IP 地址前缀 ( 1.2.3.4:80) 和域名 ( foo.example.com:80)接受文字端口号

        测试拉取gcr.io的镜像

        [root@master-1 ~]# docker pull k8s.gcr.io/kube-state-metrics/kube-state-metrics:v2.0.0


        v2.0.0: Pulling from kube-state-metrics/kube-state-metrics

        5dea5ec2316d: Pull complete

        2c0aab77c223: Pull complete

        Digest: sha256:eb2f41024a583e8795213726099c6f9432f2d64ab3754cc8ab8d00bdbc328910

        Status: Downloaded newer image for k8s.gcr.io/kube-state-metrics/kube-state-metrics:v2.0.0

        方式2: 镜像换标签

        步骤

          1. 使用Docker:镜像加速器,
          2. 登录镜像仓库docker login registry.cn-hangzhou.aliyuncs.com
          3. 拉取你需要的镜像docker pull <阿里云构建的镜像>,
          4. 然后使用docker tag <阿里云构建的镜像> <原始镜像>就可以了。

          对于kubernetes组件的镜像,比如etcd/api-server/controller-manager/kube-scheduler则可以从阿里云拉取,比如通过下面的shell脚本:

          images=(

             kube-apiserver-amd64:v1.18.4

             kube-controller-manager-amd64:v1.18.4

             kube-scheduler-amd64:v1.18.4

             kube-proxy-amd64:v1.18.4

             pause:3.2

             etcd-amd64:3.4.3

             coredns:1.6.7

          )


          for imageName in ${images[@]} ; do

             docker pull registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName

             docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName k8s.gcr.io/$imageName

          done

          国内无法直接获取 gcr.io 镜像,我们还可以将 gcr.io/<repo-name>/<image-name>:<version> 替换为 gcr.azk8s.cn/<repo-name>/<image-name>:<version>

          docker pull gcr.io/google_containers/hyperkube-amd64:v1.9.2

          docker pull gcr.azk8s.cn/google_containers/hyperkube-amd64:v1.9.2

          参考链接:

          Control Docker with systemd | Docker Documentation

          k8s.gcr.io、gcr.io仓库的镜像下载 - 粽先生 - 博客园

          相关实践学习
          深入解析Docker容器化技术
          Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
          相关文章
          |
          Prometheus Kubernetes Cloud Native
          让 K8S 在 GFW 内愉快的航行
          随着 *.azk8s.cn 限制了外部IP访问,国内的K8S环境变得越加的槽糕了,今天我们就来梳理一下目前国内可用的最新方案。
          20158 0
          |
          Kubernetes 安全 Linux
          【阿里云镜像】使用阿里巴巴开源镜像站镜像——Kubernetes 镜像
          Kubernetes 是一个开源系统,用于容器化应用的自动部署、扩缩和管理。它将构成应用的容器按逻辑单位进行分组以便于管理和发现。
          3694 0
          【阿里云镜像】使用阿里巴巴开源镜像站镜像——Kubernetes 镜像
          |
          网络安全
          如何在 Debian 系统上配置 NTP,来确保计算机时间的准确同步
          如何在 Debian 系统上配置 NTP,来确保计算机时间的准确同步
          4638 0
          如何在 Debian 系统上配置 NTP,来确保计算机时间的准确同步
          |
          Kubernetes 容器 Perl
          【kubernetes】解决: kubelet Failed to create pod sandbox: rpc error: code = Unknown desc = faile...
          【kubernetes】解决: kubelet Failed to create pod sandbox: rpc error: code = Unknown desc = faile...
          17726 0
          |
          Kubernetes 网络虚拟化 Docker
          K8S镜像下载报错解决方案(使用阿里云镜像去下载kubeadm需要的镜像文件)
          文章提供了一个解决方案,用于在无法直接访问Google镜像仓库的情况下,通过使用阿里云镜像来下载kubeadm所需的Kubernetes镜像。
          1548 4
          K8S镜像下载报错解决方案(使用阿里云镜像去下载kubeadm需要的镜像文件)
          |
          Kubernetes 应用服务中间件 nginx
          史上最全干货!Kubernetes 原理+实战总结(全文6万字,90张图,100个知识点)(上)
          史上最全干货!Kubernetes 原理+实战总结(全文6万字,90张图,100个知识点)
          52910 30
          |
          Kubernetes Docker 容器
          registry.aliyuncs.com/google_containers这个镜像仓库都有啥镜像
          registry.aliyuncs.com/google_containers这个镜像仓库都有啥镜像
          4285 1
          |
          Kubernetes 应用服务中间件 nginx
          二进制安装Kubernetes(k8s)v1.32.0
          本指南提供了一个详细的步骤,用于在Linux系统上通过二进制文件安装Kubernetes(k8s)v1.32.0,支持IPv4+IPv6双栈。具体步骤包括环境准备、系统配置、组件安装和配置等。
          4534 11
          |
          存储 Kubernetes 应用服务中间件
          Ingress-Nginx使用指南上篇
          关于Ingress-Nginx在Kubernetes中的使用指南,涵盖了从基础安装到高级特性配置的详细步骤和实战案例。
          5373 3
          Ingress-Nginx使用指南上篇
          |
          存储 Kubernetes API
          k8s学习-ConfigMap(创建、使用、更新、删除等)
          k8s学习-ConfigMap(创建、使用、更新、删除等)
          3883 0