ошибка: вы должны войти на сервер - сервер запросил у клиента учетные данные - команда "kubectl logs" выдает ошибку - PullRequest
0 голосов
/ 25 апреля 2018

Мы настроили kubernetes 1.10.1 на CoreOS с тремя узлами. Установка прошла успешно

NAME                STATUS    ROLES     AGE       VERSION
node1.example.com   Ready     master    19h       v1.10.1+coreos.0
node2.example.com   Ready     node      19h       v1.10.1+coreos.0
node3.example.com   Ready     node      19h       v1.10.1+coreos.0

NAMESPACE     NAME                                        READY     STATUS    RESTARTS   AGE
default            pod-nginx2-689b9cdffb-qrpjn       1/1       Running   0          16h
kube-system   calico-kube-controllers-568dfff588-zxqjj    1/1       Running   0          18h
kube-system   calico-node-2wwcg                           2/2       Running   0          18h
kube-system   calico-node-78nzn                           2/2       Running   0          18h
kube-system   calico-node-gbvkn                           2/2       Running   0          18h
kube-system   calico-policy-controller-6d568cc5f7-fx6bv   1/1       Running   0          18h
kube-system   kube-apiserver-x66dh                        1/1       Running   4          18h
kube-system   kube-controller-manager-787f887b67-q6gts    1/1       Running   0          18h
kube-system   kube-dns-79ccb5d8df-b9skr                   3/3       Running   0          18h
kube-system   kube-proxy-gb2wj                            1/1       Running   0          18h
kube-system   kube-proxy-qtxgv                            1/1       Running   0          18h
kube-system   kube-proxy-v7wnf                            1/1       Running   0          18h
kube-system   kube-scheduler-68d5b648c-54925              1/1       Running   0          18h
kube-system   pod-checkpointer-vpvg5                      1/1       Running   0          18h

Но когда я пытаюсь просмотреть журналы любых пакетов, kubectl выдает следующую ошибку:

kubectl logs -f pod-nginx2-689b9cdffb-qrpjn ошибка: вы должны быть зарегистрированы на сервер (сервер попросил клиента предоставить учетные данные (pods / log pod-nginx2-689b9cdffb-qrpjn))

А также попытка проникнуть внутрь модулей (используя команду EXEC kubectl) выдает следующую ошибку:

kubectl exec -ti pod-nginx2-689b9cdffb-qrpjn ошибка bash: невозможно обновить соединение: не авторизовано

Файл службы Kubelet:

Description=Kubelet via Hyperkube ACI
[Service]
EnvironmentFile=/etc/kubernetes/kubelet.env
Environment="RKT_RUN_ARGS=--uuid-file-save=/var/run/kubelet-pod.uuid \
  --volume=resolv,kind=host,source=/etc/resolv.conf \
  --mount volume=resolv,target=/etc/resolv.conf \
  --volume var-lib-cni,kind=host,source=/var/lib/cni \
  --mount volume=var-lib-cni,target=/var/lib/cni \
  --volume var-log,kind=host,source=/var/log \
  --mount volume=var-log,target=/var/log"
ExecStartPre=/bin/mkdir -p /etc/kubernetes/manifests
ExecStartPre=/bin/mkdir -p /etc/kubernetes/cni/net.d
ExecStartPre=/bin/mkdir -p /etc/kubernetes/checkpoint-secrets
ExecStartPre=/bin/mkdir -p /etc/kubernetes/inactive-manifests
ExecStartPre=/bin/mkdir -p /var/lib/cni
ExecStartPre=/usr/bin/bash -c "grep 'certificate-authority-data' /etc/kubernetes/kubeconfig | awk '{print $2}' | base64 -d > /etc/kubernetes/ca.crt"
ExecStartPre=-/usr/bin/rkt rm --uuid-file=/var/run/kubelet-pod.uuid
ExecStart=/usr/lib/coreos/kubelet-wrapper \
  --kubeconfig=/etc/kubernetes/kubeconfig \
  --config=/etc/kubernetes/config \
  --cni-conf-dir=/etc/kubernetes/cni/net.d \
  --network-plugin=cni \
  --allow-privileged \
  --lock-file=/var/run/lock/kubelet.lock \
  --exit-on-lock-contention \
  --hostname-override=node1.example.com \
  --node-labels=node-role.kubernetes.io/master \
  --register-with-taints=node-role.kubernetes.io/master=:NoSchedule
ExecStop=-/usr/bin/rkt stop --uuid-file=/var/run/kubelet-pod.uuid
Restart=always
RestartSec=10
[Install]
WantedBy=multi-user.target

Файл конфигурации Kubelet

kind: KubeletConfiguration
apiVersion: kubelet.config.k8s.io/v1beta1
staticPodPath: "/etc/kubernetes/manifests"
clusterDomain: "cluster.local"
clusterDNS: [ "10.3.0.10" ]
nodeStatusUpdateFrequency: "5s"
clientCAFile: "/etc/kubernetes/ca.crt"

Мы также указали флаги "--kubelet-client-certificate" и "--kubelet-client-key" в файлах kube-apiserver.yaml:

- --kubelet-client-certificate=/etc/kubernetes/secrets/apiserver.crt
- --kubelet-client-key=/etc/kubernetes/secrets/apiserver.key

Так чего нам здесь не хватает? Заранее спасибо:)

Ответы [ 2 ]

0 голосов
/ 21 августа 2018

В общем случае, много разных ошибок в файле .kube / config вызывают это сообщение об ошибке. В моем случае я просто указал неверное имя кластера в своем конфигурационном файле (и потратил МНОГИЕ часы, пытаясь его отладить).

Когда я указал неправильное имя кластера, я получил 2 запроса на коды токенов MFA, а затем сообщение error: You must be logged in to the server (the server has asked for the client to provide credentials).

Пример:

# kubectl create -f scripts/aws-auth-cm.yaml
Assume Role MFA token code: 123456
Assume Role MFA token code: 123456
could not get token: AccessDenied: MultiFactorAuthentication failed with invalid MFA one time pass code.
0 голосов
/ 25 апреля 2018

Похоже, вы неправильно настроенный кублет :

Вы пропустили флаг --client-ca-file в файле службы Kubelet

Вот почему вы можете получить некоторую общую информацию от мастера, но не можете получить доступ к узлам.

Этот флаг отвечает за сертификат; без этого флага вы не сможете получить доступ к узлам.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...