microk8s 拉取镜像,卡在 ContainerCreating 状态

ses*_*ses 6 docker kubernetes docker-registry microk8s

如在所描述的文档(基于)。

我在 Ubuntu 上作为主机操作系统。

docker --version
Run Code Online (Sandbox Code Playgroud)

Docker 版本 18.09.6,构建 481bc77

microk8s 1.14/beta
Run Code Online (Sandbox Code Playgroud)

启用本地注册表microk2s

microk8s.enable registry
Run Code Online (Sandbox Code Playgroud)

检查:

watch microk8s.kubectl get all --all-namespaces
Run Code Online (Sandbox Code Playgroud)

容器注册表 pod/registry-577986746b-v8xqc 1/1 运行 0 36m

然后:

编辑:

sudo vim /etc/docker/daemon.json
Run Code Online (Sandbox Code Playgroud)

添加此内容:

{
  "insecure-registries" : ["127.0.0.1:32000"]
}
Run Code Online (Sandbox Code Playgroud)

重新开始:

sudo systemctl restart docker
Run Code Online (Sandbox Code Playgroud)

仔细检查,看看是否应用了不安全:

docker info | grep -A 2 Insecure
Run Code Online (Sandbox Code Playgroud)
Insecure Registries:
 127.0.0.1:32000
 127.0.0.0/8
WARNING: No swap limit support
Run Code Online (Sandbox Code Playgroud)

标签:

docker tag my-registry/my-services/my-service:0.0.1-SNAPSHOT 127.0.0.1:32000/my-service
Run Code Online (Sandbox Code Playgroud)

检查:

docker images
Run Code Online (Sandbox Code Playgroud)

127.0.0.1:32000/my-service 最新 e68f8a7e4675 19 小时前 540MB

推动:

docker push 127.0.01:32000/my-service
Run Code Online (Sandbox Code Playgroud)

我在这里看到我的图片:http : //127.0.0.1 : 32000/v2/_catalog

deployment-local.yml我有,现在正确的形象:

...spec:
  containers:
    - name: my-service-backend
      image: 127.0.0.1:32000/my-service
      imagePullPolicy: Always ...
Run Code Online (Sandbox Code Playgroud)

然后申请:

envsubst < ./.local/deployment-local.yml | microk8s.kubectl apply -f -
Run Code Online (Sandbox Code Playgroud)

我懂了: ContainerCreating

经过: microk8s.kubectl describe pods my-service-deployment-f85d5dcd5-cmd5

在事件部分:

Events:
  Type     Reason     Age                 From                     Message
  ----     ------     ----                ----                     -------
  Normal   Scheduled  107s                default-scheduler        Successfully assigned default/my-service-deployment-f85d5dcd5-z75tr to my-desktop
  Normal   Pulling    25s (x4 over 106s)  kubelet, my-desktop  Pulling image "127.0.0.1:32000/my-service"
  Warning  Failed     25s (x4 over 106s)  kubelet, my-desktop  Failed to pull image "127.0.0.1:32000/my-service": rpc error: code = Unknown desc = failed to resolve image "127.0.0.1:32000/my-service:latest": no available registry endpoint: failed to do request: Head https://127.0.0.1:32000/v2/my-service/manifests/latest: http: server gave HTTP response to HTTPS client
  Warning  Failed     25s (x4 over 106s)  kubelet, my-desktop  Error: ErrImagePull
  Normal   BackOff    10s (x5 over 105s)  kubelet, my-desktop  Back-off pulling image "127.0.0.1:32000/my-service"
  Warning  Failed     10s (x5 over 105s)  kubelet, my-desktop  Error: ImagePullBackOff
Run Code Online (Sandbox Code Playgroud)

好像我的服务卡在那里了。

问: 可能是什么原因?

更新: 将所有更改为localhost帮助,这意味着我现在可以在浏览器中看到:http://localhost:32000/v2/_catalog

{"repositories":["my-service"]}
Run Code Online (Sandbox Code Playgroud)

但它只在 Firefox 中有效......很奇怪。在 chrome 中待定..

仍然:

Events:
  Type     Reason          Age                    From                    Message
  ----     ------          ----                   ----                    -------
  Normal   Scheduled       161m                   default-scheduler       Successfully assigned default/my-service-deployment-6d4c5587df-72xvd to my-laptop
  Normal   Pulling         160m (x4 over 161m)    kubelet, my-laptop  Pulling image "localhost/my-service"
  Warning  Failed          160m (x4 over 161m)    kubelet, my-laptop  Failed to pull image "localhost/my-service": rpc error: code = Unknown desc = failed to resolve image "localhost/my-service:latest": no available registry endpoint: failed to do request: Head https://localhost/v2/my-service/manifests/latest: dial tcp 127.0.0.1:443: connect: connection refused
  Warning  Failed          160m (x4 over 161m)    kubelet, my-laptop  Error: ErrImagePull
  Warning  Failed          159m (x6 over 161m)    kubelet, my-laptop  Error: ImagePullBackOff
  Normal   BackOff         131m (x132 over 161m)  kubelet, my-laptop  Back-off pulling image "localhost/my-service"
  Normal   SandboxChanged  22m                    kubelet, my-laptop  Pod sandbox changed, it will be killed and re-created.
  Normal   Pulling         21m (x4 over 22m)      kubelet, my-laptop  Pulling image "localhost/my-service"
  Warning  Failed          21m (x4 over 22m)      kubelet, my-laptop  Failed to pull image "localhost/my-service": rpc error: code = Unknown desc = failed to resolve image "localhost/my-service:latest": no available registry endpoint: failed to do request: Head https://localhost/v2/my-service/manifests/latest: dial tcp 127.0.0.1:443: connect: connection refused
  Warning  Failed          21m (x4 over 22m)      kubelet, my-laptop  Error: ErrImagePull
  Warning  Failed          20m (x6 over 22m)      kubelet, my-laptop  Error: ImagePullBackOff
  Normal   BackOff         2m22s (x87 over 22m)   kubelet, my-laptop  Back-off pulling image "localhost/my-service"
Run Code Online (Sandbox Code Playgroud)

似乎它试图通过 https 连接..

——

好的.. 必须为 yml 图像添加端口:部分。将接受下面的答案。谢谢。

Pjo*_*erS 3

在 microk8s 中localhost127.0.0.1之间有很大的不同。正如您所提到的,您基于Stack 案例,并且用户正在使用localhost

这里的主要问题是错误no available registry endpoint: failed to do request:。这意味着 microk8s 找不到端点。

如果您在下面运行command,您将得到相同的输出

$ cat /var/snap/microk8s/current/args/containerd-template.toml | grep endpoint

endpoint = ["https://registry-1.docker.io"]
endpoint = ["http://localhost:32000"]
Run Code Online (Sandbox Code Playgroud)

正如您在 microk8s 端点中看到的那样,端点是localhost而不是 127.0.0.1

请更改deployment-local.yaml中的图像

...spec:
  containers:
    - name: my-service-backend
      image: localhost/my-service
      imagePullPolicy: Always ...
Run Code Online (Sandbox Code Playgroud)

如果您会遇到任何其他问题,请告诉我。

就我而言,我不需要使用 localhost 再次标记和推送图像,只需要更改 YAML。