Kubernetes kubeadm v1.7.2主机名“&引用;联系不到

Kubernetes kubeadm v1.7.2主机名“&引用;联系不到,kubernetes,kubeadm,Kubernetes,Kubeadm,我正在尝试安装具有2个节点的kubernetes群集(v1.7.2)。使用weave作为cni。加入另一个节点时,kubeadm会抱怨主机名 [root@ctdpc001572 ~]# kubeadm join --token c5ba8a.6bcb25f017648271 10.41.30.50:6443 [kubeadm] WARNING: kubeadm is in beta, please do not use it for production clusters. [preflight

我正在尝试安装具有2个节点的kubernetes群集(v1.7.2)。使用weave作为cni。加入另一个节点时,kubeadm会抱怨主机名

[root@ctdpc001572 ~]# kubeadm join --token c5ba8a.6bcb25f017648271 10.41.30.50:6443
[kubeadm] WARNING: kubeadm is in beta, please do not use it for production clusters.
[preflight] Running pre-flight checks
[preflight] WARNING: hostname "" could not be reached
[preflight] WARNING: hostname "" lookup : no such host
[preflight] Some fatal errors occurred:
    hostname "" a DNS-1123 subdomain must consist of lower case alphanumeric characters, '-' or '.', and must start and end with an alphanumeric character (e.g. 'example.com', regex used for validation is '[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*')
[preflight] If you know what you are doing, you can skip pre-flight checks with `--skip-preflight-checks`
我使用的是centos 7.3

Linux ctdpc001572.ctd.internal.com 3.10.0-514.26.2.el7.x86_64 #1 SMP Tue Jul 4 15:04:05 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux
已安装的yum软件包

Loaded plugins: fastestmirror, langpacks, versionlock
Loading mirror speeds from cached hostfile
Installed Packages
kubeadm.x86_64                                                                                  1.7.2-0                                                                                       @kubernetes
kubectl.x86_64                                                                                  1.7.2-0                                                                                       @kubernetes
kubelet.x86_64                                                                                  1.7.2-0                                                                                       @kubernetes
kubernetes-cni.x86_64                                                                           0.5.1-0                                                                                       @kubernetes
Available Packages
kubernetes.x86_64                                                                               1.5.2-0.7.git269f928.el7                                                                      extras     
kubernetes-client.x86_64                                                                        1.5.2-0.7.git269f928.el7                                                                      extras     
kubernetes-master.x86_64                                                                        1.5.2-0.7.git269f928.el7                                                                      extras     
kubernetes-node.x86_64                                                                          1.5.2-0.7.git269f928.el7                                                                      extras     
kubernetes-unit-test.x86_64                                                                     1.5.2-0.7.git269f928.el7                                                                      extras    
步骤:

$ yum install -y docker kubelet kubeadm kubectl kubernetes-cni
$ systemctl enable docker && systemctl start docker
$ systemctl enable kubelet && systemctl start kubelet
$ systemctl stop firewalld; systemctl disable firewalld
$ kubeadm init --apiserver-advertise-address=10.41.30.50
$ mkdir $HOME/.kube
$ cp /etc/kubernetes/admin.conf $HOME/.kube/config

#set IPALLOC_RANGE to 172.40.0.0/16 in https://git.io/weave-kube-1.6
$ kubectl apply -f weave-kube-1.6.yaml

#schedule pods on master
$ kubectl taint nodes --all node-role.kubernetes.io/master-

#disable access control
$ kubectl create clusterrolebinding permissive-binding \
  --clusterrole=cluster-admin \
  --user=admin \
  --user=kubelet \
  --group=system:serviceaccounts

# joining other node
$ kubeadm join --token c5ba8a.6bcb25f017648271 10.41.30.50:6443
跑步时

kubeadm join --token c5ba8a.6bcb25f017648271 10.41.30.50:6443 --skip-preflight-checks
我在weave kube吊舱中看到以下错误:

2017/07/29 16:36:39 error contacting APIServer: Get https://10.96.0.1:443/api/v1/nodes: dial tcp 10.96.0.1:443: i/o timeout; trying with fallback: http://localhost:8080
2017/07/29 16:36:39 Could not get peers: Get http://localhost:8080/api/v1/nodes: dial tcp [::1]:8080: getsockopt: connection refused
Failed to get peers

在其他节点上手动添加ip路由解决了此问题:汗水微笑:

route add 10.96.0.1 gw <your real master IP>
线路增加10.96.0.1 gw

看起来您的仆从节点的主机名非法。 主机名不能包含“-”,您的主机名是DNS-1123 在/etc/hostname和/etc/hosts中将其更改为正确。 一切正常。

运行此命令

kubeadm join --skip-preflight-checks --token TOKEN HOST:PORT 

我也遇到了同样的问题,法贡的回答起了作用

然后我进一步深入研究了这个问题,我最终将警告kubeadm报告的主机名添加到
/etc/hosts
,并删除了手动添加的路由规则。它还在工作


如果有人再次遇到此问题,则会提示:)

错误消息中的DNS-1123表示RFC 1123。这不是我的域名。