Kubernetes不能从不安全的注册表中拉出ANS无法从离线群集上的本地图像运行容器



我正在处理离线群集(机器没有互联网访问),使用Ansible和Docker撰写脚本部署Docker图像。我的服务器是Centos7。我已经在机器上设置了一个不安全的码头注册表。我们将改变环境,我正在安装kubernetes来管理我的集装箱。

我遵循本指南安装kubernetes:https://severalnines.com/blog/installing-kubernetes-cluster-minions-centos7-manage-pods-Services

安装后,我尝试启动一个测试吊舱。这是Pod的YML,使用

启动
    kubectl -f create nginx.yml

在这里yml:

    apiVersion: v1
    kind: Pod
    metadata: 
      name: nginx
    spec:
      containers:
      - name: nginx
        image: [my_registry_addr]:[my_registry_port]/nginx:v1 
        ports:
        - containerPort: 80

我使用Kubectl描述以获取有关错误的更多信息:

    Name:       nginx
    Namespace:  default
    Node:       [my node]
    Start Time: Fri, 15 Sep 2017 11:29:05 +0200
    Labels:     <none>
    Status:     Pending
    IP:     
    Controllers:    <none>
    Containers:
      nginx:
        Container ID:       
        Image:          [my_registry_addr]:[my_registry_port]/nginx:v1
        Image ID:           
        Port:           80/TCP
        State:          Waiting
          Reason:           ContainerCreating
        Ready:          False
        Restart Count:      0
        Volume Mounts:      <none>
        Environment Variables:  <none>
    Conditions:
      Type      Status
      Initialized   True 
      Ready     False 
      PodScheduled  True 
    No volumes.
    QoS Class:  BestEffort
    Tolerations:    <none>
    Events:
      FirstSeen LastSeen    Count   From                SubObjectPath           Type        Reason      Message
      --------- --------    -----   ----                -------------   --------    ------      -------
      2m        2m      1   {default-scheduler }                Normal      Scheduled   Successfully assigned nginx to [my kubernet node]
      1m        1m      2   {kubelet [my kubernet node]}            Warning     FailedSync  Error syncing pod, skipping: failed to "StartContainer" for "POD" with ErrImagePull: "Error while pulling image: Get https://index.docker.io/v1/repositories/library/[my_registry_addr]/images: dial tcp: lookup index.docker.io on [kubernet_master_ip]:53: server misbehaving"
      54s   54s 1   {kubelet [my kubernet node]}        Warning FailedSync  Error syncing pod, skipping: failed to "StartContainer" for "POD" with ImagePullBackOff: "Back-off pulling image "[my_registry_addr]:[my_registry_port]""
      8s    8s  1   {kubelet [my kubernet node]}        Warning FailedSync  Error syncing pod, skipping: failed to "StartContainer" for "POD" with ErrImagePull: "Network timed out while trying to connect to https://index.docker.io/v1/repositories/library/[my_registry_addr]/images. You may want to check your internet connection or if you are behind a proxy."

然后,我转到我的节点并使用journalctl -xe

    sept. 15 11:22:02 [my_node_ip] dockerd-current[9861]: time="2017-09-15T11:22:02.350930396+02:00" level=info msg="{Action=create, LoginUID=4294967295, PID=11555}"
    sept. 15 11:22:17 [my_node_ip] dockerd-current[9861]: time="2017-09-15T11:22:17.351536727+02:00" level=warning msg="Error getting v2 registry: Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers)"
    sept. 15 11:22:17 [my_node_ip] dockerd-current[9861]: time="2017-09-15T11:22:17.351606330+02:00" level=error msg="Attempting next endpoint for pull after error: Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers)"
    sept. 15 11:22:32 [my_node_ip] dockerd-current[9861]: time="2017-09-15T11:22:32.353946452+02:00" level=error msg="Not continuing with pull after error: Error while pulling image: Get https://index.docker.io/v1/repositories/library/[my_registry_ip]/images: dial tcp: lookup index.docker.io on [kubernet_master_ip]:53: server misbehaving"
    sept. 15 11:22:32 [my_node_ip] kubelet[11555]: E0915 11:22:32.354309   11555 docker_manager.go:2161] Failed to create pod infra container: ErrImagePull; Skipping pod "nginx_default(8b5c40e5-99f4-11e7-98db-f8bc12456ee4)": Error while pulling image: Get https://index.docker.io/v1/repositories/library/[my_registry_ip]/images: dial tcp: lookup index.docker.io on [kubernet_master_ip]:53: server misbehaving
    sept. 15 11:22:32 [my_node_ip] kubelet[11555]: E0915 11:22:32.354390   11555 pod_workers.go:184] Error syncing pod 8b5c40e5-99f4-11e7-98db-f8bc12456ee4, skipping: failed to "StartContainer" for "POD" with ErrImagePull: "Error while pulling image: Get https://index.docker.io/v1/repositories/library/[my_registry_ip]/images: dial tcp: lookup index.docker.io on [kubernet_master_ip]:53: server misbehaving"
    sept. 15 11:22:44 [my_node_ip] dockerd-current[9861]: time="2017-09-15T11:22:44.350708175+02:00" level=error msg="Handler for GET /v1.24/images/[my_registry_ip]:[my_registry_port]/json returned error: No such image: [my_registry_ip]:[my_registry_port]"

我确定我的码头配置很好,因为我每天都在使用Ansible或Mesos。

Docker版本为1.12.6,Kubernetes版本为1.5.2

我现在该怎么办?我没有找到此用法的任何配置密钥。

当我看到拉动失败时,我会手动在所有节点上拉图像。我放了一个标签,以确保Kubernetes尝试将其拉动为默认值,并设置" ImagePullPolicy:Ifnotpresent"

指定Docker映像的语法是:

[docker_registry]/[image_name]:[image_tag]

在您的清单文件中,您使用了":"将Docker存储库主机和存储库正在侦听的端口分开。我猜是Docker私有注册表的默认端口是5000。因此,从

更改图像声明
Image:          [my_registry_addr]:[my_registry_port]/nginx:v1

to

Image:          [my_registry_addr]/nginx:v1

另外,通过执行ping检查网络连接从工人节点到docker注册表。

ping [my_registry_addr]

如果您仍然想检查端口443是否在注册表上打开

curl telnet://[my_registry_addr]:443

希望会有所帮助。

我终于找到了问题所在。

要工作,kubernetes需要一个暂停容器。Kubernetes试图在Internet上找到暂停容器。

我在注册表上部署了一个自定义暂停容器,我将kubernetes暂停容器设置为此图像。

之后,Kubernetes的工作就像魅力。

最新更新