从私有仓库拉取镜像

    • 你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 如果你还没有集群,你可以通过 构建一 个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

      要获知版本信息,请输入 kubectl version.

    你需要 Docker ID 和密码来进行本练习。

    登录 Docker 镜像仓库

    在个人电脑上,要想拉取私有镜像必须在镜像仓库上进行身份验证。

    当出现提示时,输入 Docker 用户名和密码。

    登录过程会创建或更新保存有授权令牌的 config.json 文件。

    查看 config.json 文件:

    1. cat ~/.docker/config.json

    输出结果包含类似于以下内容的部分:

    1. {
    2. "auths": {
    3. "https://index.docker.io/v1/": {
    4. "auth": "c3R...zE2"
    5. }
    6. }
    7. }

    Kubernetes 集群使用 docker-registry 类型的 Secret 来通过容器仓库的身份验证,进而提取私有映像。

    创建 Secret,命名为 regcred

    1. kubectl create secret docker-registry regcred \
    2. --docker-username=<你的用户名> \
    3. --docker-password=<你的密码> \
    4. --docker-email=<你的邮箱地址>

    在这里:

    • <your-registry-server> 是你的私有 Docker 仓库全限定域名(FQDN)。 (参考 中关于 DockerHub 的部分)
    • 是你的 Docker 用户名。
    • <your-pword> 是你的 Docker 密码。
    • <your-email> 是你的 Docker 邮箱。

    这样你就成功地将集群中的 Docker 凭据设置为名为 regcred 的 Secret。

    检查 Secret regcred

    要了解你创建的 regcred Secret 的内容,可以用 YAML 格式进行查看:

    输出和下面类似:

    1. apiVersion: v1
    2. data:
    3. .dockerconfigjson: eyJodHRwczovL2luZGV4L ... J0QUl6RTIifX0=
    4. kind: Secret
    5. metadata:
    6. ...
    7. name: regcred
    8. ...
    9. type: kubernetes.io/dockerconfigjson

    .dockerconfigjson 字段的值是 Docker 凭据的 base64 表示。

    要了解 dockerconfigjson 字段中的内容,请将 Secret 数据转换为可读格式:

    1. kubectl get secret regcred --output="jsonpath={.data.\.dockerconfigjson}" | base64 --decode
    1. {"auths":{"yourprivateregistry.com":{"username":"janedoe","password":"xxxxxxxxxxx","email":"jdoe@example.com","auth":"c3R...zE2"}}}

    要了解 auth 字段中的内容,请将 base64 编码过的数据转换为可读格式:

    输出结果中,用户名和密码用 : 链接,类似下面这样:

      注意,Secret 数据包含与本地 文件类似的授权令牌。

      这样你就已经成功地将 Docker 凭据设置为集群中的名为 regcred 的 Secret。

      下面是一个 Pod 配置文件,它需要访问 regcred 中的 Docker 凭据:

      pods/private-reg-pod.yaml

      1. apiVersion: v1
      2. kind: Pod
      3. metadata:
      4. name: private-reg
      5. spec:
      6. containers:
      7. - name: private-reg-container
      8. image: <your-private-image>
      9. imagePullSecrets:
      10. - name: regcred

      下载上述文件:

      1. wget -O my-private-reg-pod.yaml https://k8s.io/examples/pods/private-reg-pod.yaml

      my-private-reg-pod.yaml 文件中,使用私有仓库的镜像路径替换 <your-private-image>,例如:

      创建使用了你的 Secret 的 Pod,并检查它是否正常运行:

      1. kubectl apply -f my-private-reg-pod.yaml
      2. kubectl get pod private-reg

      接下来